a 标签的跳转机制

结合着好未来秋招的一道面试题讲解一下 a 标签的跳转机制。

题目代码

html 复制代码
<a href="https://www.baidu.com"
   onclick="window.open('https://www.csdn.net')">
  link
</a>

会弹出哪个页面?

会同时打开两个页面:

  • 新窗口 / 新标签: https://www.csdn.net
  • 当前页面跳转到: https://www.baidu.com

注意!如果 href 的值为 baidu.com ,则会跳转到 http://127.0.0.1:5500/www.baidu.com(我这里用的 vscode 插件会开启一个 5500 端口的页面)


  1. 点击 <a> 触发 onclick

  2. 执行 JS:

    js 复制代码
    window.open('https://www.csdn.net')

    → 打开新窗口(或新标签)

  3. JS 执行完毕

  4. 浏览器继续执行 a 标签的默认行为

    html 复制代码
    href="https://www.baidu.com"

JS 不会自动阻止默认行为

怎么禁用 onclick?

✅ 方式一:return false

html 复制代码
<a href="https://www.baidu.com"
   onclick="return false">
  link
</a>

👉 return false =

✔️ preventDefault

✔️ stopPropagation


✅ 方式二:event.preventDefault

html 复制代码
<a href="https://www.baidu.com"
   onclick="event.preventDefault()">
  link
</a>

✅ 方式三:JS 解绑(工程化)

js 复制代码
a.onclick = null;

js 复制代码
a.removeEventListener('click', handler);

❌ 错误理解澄清

js 复制代码
onclick = () => {}

这样不会阻止 a 的默认跳转


SPA 中为什么还用 <a>

  • 框架(Vue / React)会:

    • 拦截 a 的默认行为
    • 用 history API 做无刷新跳转
  • 但:

    • 语义仍然正确
    • 可降级

a vs button:

维度 <a> <button>
语义 超链接(导航) 操作按钮
是否原生跳转
SEO ✅ 可被爬虫识别
右键新开
中键点击
无 JS 是否可用
可访问性 ✅ 天生支持 ⚠️ 需处理
相关推荐
明月_清风1 天前
打字机效果优化:用 requestAnimationFrame 缓冲高频文字更新
前端·javascript
明月_清风1 天前
Markdown 预解析:别等全文完了再渲染,如何流式增量渲染代码块和公式?
前端·javascript
掘金安东尼1 天前
用 CSS 打造完美的饼图
前端·css
掘金安东尼1 天前
纯 CSS 实现弹性文字效果
前端·css
牛奶1 天前
Vue 基础理论 & API 使用
前端·vue.js·面试
牛奶1 天前
Vue 底层原理 & 新特性
前端·vue.js·面试
anOnion1 天前
构建无障碍组件之Radio group pattern
前端·html·交互设计
pe7er1 天前
状态提升:前端开发中的状态管理的设计思想
前端·vue.js·react.js
SoaringHeart1 天前
Flutter调试组件:打印任意组件尺寸位置信息 NRenderBox
前端·flutter
晚风予星1 天前
Ant Design Token Lens 迎来了全面升级!支持在 .tsx 或 .ts 文件中直接使用 Design Token
前端·react.js·visual studio code