标签用于统一设置页面内所有相对URL的解析基准,必须置于中且仅能出现一次;其href值须为绝对URL或根相对路径,动态修改无效。

标签的作用是设置页面内所有相对 URL 的解析基准
它不改变已有绝对 URL,只影响 、、、、 等标签中出现的相对路径。浏览器在解析这些相对地址时,会以 指定的 href 值为起点,而非当前页面 URL。
必须放在 中,且只能出现一次
HTML5 明确规定: 只能作为 的子元素,且整个文档中最多允许一个。如果写了多个,只有第一个生效;如果写在 里,多数浏览器会忽略或触发解析警告。
- 错误位置示例:
- 正确写法:
- 若同时设
href和target,两者都生效,例如:
——所有相对链接默认用/static/解析,且点击后在新窗口打开
href 值必须是绝对 URL 或根相对路径(/ 开头)
不能是普通相对路径(如 ./assets/ 或 images/),否则浏览器会静默忽略该 标签,不报错但也不生效。
- ✅ 合法:
href="https://example.com/assets/"、href="/assets/" - ❌ 无效:
href="assets/"、href="../static/"、href="data:," - 注意:即使页面本身是
file://协议,仍可生效,但部分本地开发场景下(如直接双击打开 HTML 文件)可能受限于跨源策略,导致资源加载失败
动态修改 不会重新解析已存在的相对 URL
DOM 中插入或修改 元素,只会影响后续解析的相对 URL(比如新插入的 ),不会重写已渲染的链接或已发起的资源请求。这点常被误认为“刷新 base 就能修复路径”,实际无效。
立即学习“前端免费学习笔记(深入)”;
- JavaScript 修改无效示例:
document.querySelector('base').href = 'https://new-cdn.com/';——已有仍按旧 base 加载
- 真正需要切换基准路径时,应提前确定并静态写入
,或改用 JavaScript 手动拼接 URL(如new URL('logo.png', document.baseURI)) - 服务端渲染(SSR)或构建工具(如 Webpack/Vite)中,更推荐通过配置统一处理资源路径,而非依赖
,避免运行时歧义
—— 它容易引发隐式行为,尤其在路由(如 SPA 的 /user/123 页面)和资源路径混用时,href="/api" 和 href="api" 会因 base 设置产生完全不同的请求目标。真要用,务必全链路验证所有相对引用是否如预期解析。











