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 是否可用
可访问性 ✅ 天生支持 ⚠️ 需处理
相关推荐
狂炫冰美式2 小时前
当硅基神明撞上人类的“叹息之墙”:距离证明哥德巴赫猜想,AI还有多远?
前端·算法·架构
毕设源码-邱学长2 小时前
【开题答辩全过程】以 基于Vue的爱心公益募捐平台的设计与实现为例,包含答辩的问题和答案
前端·javascript·vue.js
IT_陈寒2 小时前
Redis实战精要:5种高频使用场景与性能优化全解析|得物技术
前端·人工智能·后端
前端小白在前进3 小时前
力扣刷题:千位分割数
javascript·算法·leetcode
Hilaku3 小时前
那个把代码写得亲妈都不认的同事,最后被劝退了🤷‍♂️
前端·javascript·代码规范
南囝coding3 小时前
Node.js 原生功能狂飙,15 个热门 npm 包要失业了
前端·后端
Dragon Wu3 小时前
TanStack Query(React Query) 常用api及操作总结
前端·javascript·前端框架
火柴就是我3 小时前
canvas.rotate(rotation); 到底是往哪个方向转动
前端
光影少年3 小时前
前端算法新手如何刷算法?
前端·算法