标签用于统一设置页面内所有相对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 文件)可能受限于跨源策略,导致资源加载失败 不会重新解析已存在的相对 URLDOM 中插入或修改 元素,只会影响后续解析的相对 URL(比如新插入的 ),不会重写已渲染的链接或已发起的资源请求。这点常被误认为“刷新 base 就能修复路径”,实际无效。
docume——已有nt.querySelector('base').href = 'https://new-cdn.com/';
仍按旧 base 加载,或改用 JavaScript 手动拼接 URL(如 new URL('logo.png', document.baseURI)),避免运行时歧义 —— 它容易引发隐式行为,尤其在路由(如 SPA 的 /user/123 页面)和资源路径混用时,href="/api" 和 href="api" 会因 base 设置产生完全不同的请求目标。真要用,务必全链路验证所有相对引用是否如预期解析。