正确使用标签需注意路径、target属性、锚点及SPA适配:相对路径以当前文件为起点,绝对路径以/开头;新开标签页须加rel="noopener noreferrer";锚点id需严格匹配且URL编码中文;SPA中优先用路由API。
标签链接本地 HTML 文件时路径写错是最大问题直接写文件名(比如 page.html)只在同目录下有效;一旦文件结构变深,href 就会 404。常见错误是把路径当操作系统路径抄进来,比如 C:\project\about.html 或 /Users/me/index.html —— 浏览器根本不认这种写法。
../,同级用 file.html,子目录用 sub/page.html
/ 开头:比如站点部署后根目录有 /contact.html,就写 href="/contact.html"
file:// 前缀——本地双击打开 HTML 时可能临时生效,但一旦走 HTTP(S) 服务(如 localhost:3000)就失效target 属性不设或设错会导致页面跳转体验断裂默认点击链接会在当前页跳转,对文档内导航或侧边栏菜单很不友好。但乱设 target="_blank" 又容易引发安全与体验问题。
rel="noopener noreferrer",否则存在 window.opener 安全隐患target="frame-name",前提是页面中已有
跳转,Vue/React 项目应优先用 或 useNavigate() 等路由 API# 后面不能有空格或特殊字符锚点跳转依赖 URL 中 # 后的片段标识符(fragment identifier),浏览器只会原样匹配 id 值,大小写敏感、不自动编码空格。
id 属性,不是 class:第二部分
才能被 href="#section-2" 正确定位,链接得写成 href="#%E5%B8%B8%E8%A7%81%E9%97%AE%E9%A2%98",更稳妥的做法是用英文短横线命名 id="faq"- 页面加载后才动态生成的锚点元素?需用 JavaScript 监听
h
ashchange 事件并滚动,纯 HTML 不生效
关于我
博客文章
产品首页(网站根路径)
安装步骤
外部网站
链接本身很简单,真正卡住人的永远是路径层级判断、部署后根路径变化、以及锚点和动态内容的配合。别依赖“看起来能点开”,用浏览器开发者工具的 Network 面板看实际请求的 URL 是不是 200,比猜快得多。