下划线需用独立元素(如span)置于导航容器内并绝对定位,通过JS监听mouseenter/mouseleave及touchstart/focus事件,结合getBoundingClientRect计算位置,配合transform和width的transition实现平滑跟随。导航栏下划线不跟鼠标,transform 用错位置了常见错误是给 a 标签直接加 hover 和 transition,结果下划线在每个链接里独立出现、无法平滑移动。真正要动的是那个"共享"的下划线元素(比如一个 span 或伪元素),它得脱离单个链接,放在导航容器里统一控制。实操建议:立即学习"前端免费学习笔记(深入)";用一个绝对定位的 span 作为下划线,初始 width: 0、left: 0监听每个 a 的 mouseenter,读取它的 offsetLeft 和 offsetWidth,再用 transform: translateX() + width 更新下划线位置尺寸必须给下划线元素加 transition: transform 0.3s ease, width 0.3s ease,只写 all 容易卡顿:hover 伪类没法跨元素联动,得靠 JS 监听CSS 的 :hover 只能影响自身或后代,不能让父容器里的另一个子元素(如下划线)响应某个 a 的悬停。想让下划线"追着鼠标跑",纯 CSS 没法做到动态定位------除非你放弃平滑过渡,改用每个 a 自带固定位置的伪元素下划线(那就不是"随鼠标移动"了)。实操建议:立即学习"前端免费学习笔记(深入)";把下划线 DOM 节点放在 nav 内部最末尾,和 a 同级用 addEventListener('mouseenter', ...) 绑定到每个 a,避免用 onmouseover(会冒泡触发多次)别忘了加 mouseleave 回退逻辑:比如移出导航时,下划线缓慢缩回中间或收起用 getBoundingClientRect() 比 offsetLeft 更可靠如果导航栏有 padding、flex 布局或 transform 缩放,offsetLeft 会算不准位置,导致下划线偏移。尤其在响应式页面里,这个坑几乎必踩。 Cleanup.pictures 智能移除图片中的物体、文本、污迹、人物或任何不想要的东西
相关推荐
兵慌码乱18 小时前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析金銀銅鐵19 小时前
[Python] 体验用欧几里得算法计算最大公约数的过程FreakStudio1 天前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发用户0332126663671 天前
使用 Python 从零创建 Word 文档Csvn1 天前
Python 两大经典坑点 —— 可变默认参数 & 闭包延迟绑定曲幽1 天前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了用户556918817531 天前
#从脚本到独立程序:Python + Playwright 批量抓取的完整踩坑记录倔强的石头_1 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测兵慌码乱2 天前
基于 MediaPipe 与 PySide2 的手势交互音乐控制系统实现:轻量化视觉交互全流程解析luckdewei2 天前
FastAPI 资产管理系统实战:复杂 ORM 关联、Alembic 迁移与 N+1 查询优化