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 是否可用
可访问性 ✅ 天生支持 ⚠️ 需处理
相关推荐
yuanyxh2 小时前
Mac 软件推荐
前端·javascript·程序员
万少2 小时前
AtomCode开发微信小程序《谁去呀》 全流程
前端·javascript·后端
某人辛木2 小时前
Web自动化测试
前端·python·pycharm·pytest
Kagol3 小时前
Superpowers GSD gstack AgentSkills深度测评
前端·人工智能
excel4 小时前
JavaScript 字符串与模板字面量:从表象到本质理解
前端
京东云开发者4 小时前
当AI成为导演-如何用AI创作动漫短剧
前端
李白的天不白5 小时前
使用 SmartAdmin 进行前后端开发
java·前端
乘风gg5 小时前
🤡PUA AI Coding 工具 的 10 条终极语录
前端·ai编程·claude
学Linux的语莫5 小时前
Vue 3 入门教程
前端·javascript·vue.js
怕浪猫5 小时前
第一章、Chrome DevTools Protocol (CDP) 详解
前端·javascript·chrome