新闻中心

如何用css实现导航栏下划线过渡

2025-10-27
浏览次数:
返回列表
答案是利用伪元素和CSS的transform与transition实现导航栏下划线过渡。首先构建导航HTML结构,设置flex布局与链接样式,再通过::after创建绝对定位的下划线,初始宽度为0,配合transition定义动画时长与函数,hover时宽度变为100%或使用scaleX从中心展开,实现平滑过渡效果。

如何用css实现导航栏下划线过渡

实现导航栏下划线过渡效果,关键在于利用伪元素和CSS的transformtransition属性。这种方式既美观又性能良好。

1. 基本HTML结构

先构建一个简单的导航结构:

<n* class="n*bar">
  <a href="#" class="n*-link">首页</a>
  <a href="#" class="n*-link">关于</a>
  <a href="#" class="n*-link">服务</a>
  <a href="#" class="n*-link">联系</a>
</n*>

2. 设置基础样式

给导航链接设置基本样式,隐藏默认下划线,定位伪元素:

.n*bar {
  display: flex;
  gap: 30px;
  padding: 20px;
  background: #fff;
}

.n*-link {
  text-decoration: none;
  color: #333;
  position: relative;
  padding: 10px 0;
}

3. 添加下划线伪元素

使用::after创建下划线,并设置过渡动画:

小爱开放平台 小爱开放平台

小米旗下小爱开放平台

小爱开放平台 291 查看详情 小爱开放平台
.n*-link::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  height: 2px;
  background-color: #007bff;
  transition: width 0.3s ease;
}

.n*-link:hover::after {
  width: 100%;
}

4. 可选:更平滑的居中展开效果

如果想让下划线从中间向两边展开,可以调整伪元素的起点和变换原点:

.n*-link::after {
  left: 50%;
  transform: translateX(-50%) scaleX(0);
  transform-origin: center;
  transition: transform 0.3s ease;
}

.n*-link:hover::after {
  transform: translateX(-50%) scaleX(1);
}

这种方法使用scaleX控制宽度变化,视觉上更流畅,且避免重绘。

基本上就这些,核心是伪元素 + 过渡控制。不复杂但容易忽略细节。

以上就是如何用css实现导航栏下划线过渡的详细内容,更多请关注其它相关文章!


# 中文网  # 网站优化单页面  # seo快排犯法吗  # 论坛网站建设系统  # 网站广告推广赚钱吗是真的吗  # 揭阳模板网站推广营销  # seo0399  # 大连自考网站建设  # seo刻羽云  # 网站推广论坛ppt  # 夜猫电影网站建设  # 可选  # 解决问题  # css  # 相关文章  # 选择器  # 两种类型  # 中不  # 如何用  # 小爱  # 下划线  # 重绘  # 绝对定位  # flex布局  # 伪元素  # html 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 随机参数递归函数的基准调用次数与时间复杂度探究  J*aScript井字棋(Tic-Tac-Toe)核心交互逻辑实现教程  拷贝漫画电脑版官网入口 拷贝漫画(PC版)在线直达  J*aScript中向JSON对象添加新属性的正确姿势  sublime怎么覆盖插件的默认快捷键_sublime快捷键优先级与设置  MongoDB Aggregation:在嵌套对象数组中精确匹配ObjectId  Python getattr() 异常处理深度解析:避免程序意外退出  使用 Pandas 高效处理 .dat 文件:数据清洗与数值计算实战  Vue.js 图片显示异常排查:理解应用挂载范围与DOM ID唯一性  动漫共和国防屏蔽稳定域名-动漫共和国官方正版直达通道  聚水潭ERP登录页面入口 聚水潭ERP官网登录界面  处理Kafka消费者会话超时:深入理解消息处理语义与幂等性  微信群消息显示延迟如何解决 微信群消息刷新优化方法  Odoo 16:在表单视图中基于当前记录动态修改Tree视图属性  品牌机怎么重装系统 联想/戴尔/惠普笔记本恢复出厂系统教程  在Go语言中利用后缀数组处理多字符串:实现高效文本匹配与自动补全  qq游戏手机版下载安装_qq游戏移动端入口  Win11截图该按哪些键 Win11截屏完整流程解析【教程】  Pandas DataFrame:高效添加条件计算列  如何提高微信支付的安全性_微信支付安全防护与设置建议  j*a toString()的覆盖  微信语音通话掉线如何解决 微信语音通话稳定优化方法  Kafka Streams中基于消息头条件过滤消息的实现指南  新手怎么开始学化妆 零基础化妆入门教程  Golang如何安装Swagger工具_GoSwagger文档生成环境  cad如何更改注释性对象的比例_cad注释性比例调整方法  12306选座怎么选到特殊座位_12306特殊座位选择注意事项  Golang切片为何属于引用类型_Golang slice底层结构与引用语义说明  J*aScript数据结构转换:将对象数组按类别分组  夸克浏览器桌面版同步不了书签怎么处理 夸克浏览器跨设备同步异常解决方案  KFC套餐升级怎么获取优惠代码_KFC套餐升级活动与优惠代码获取方法  优化Log4j2控制台输出性能:解决异步日志瓶颈  age动漫网站入口 age动漫官网直接访问入口  Mac终端命令大全_Mac常用Terminal指令速查  J*aScript对象创建方式_J*aScript设计模式应用  在命令行怎么运行html项目_命令行运行html项目方法【教程】  在Go Martini框架中高效服务动态生成图像的实践指南  狙击外星人小游戏开始_狙击外星人小游戏立即开始  2025年云电脑操作系统体验 | 无需本地硬件,随时随地使用高性能PC  美团外卖商家服务中心入口 美团商家版官网入口  Win11 USB传输速度慢怎么解决 Win11 USB驱动更新与设置  俄罗斯Yandex搜索引擎入口_Yandex官网免登录一键访问  c++中的const_cast和reinterpret_cast怎么用_c++四种类型转换  拼多多视频播放卡顿如何处理 拼多多视频播放优化技巧  2026春节假期票务安排_2026春节放假购票指南  利用Bokeh CustomJS动态控制DataTable列可见性  win11 arm版怎么安装 M1/M2 Mac虚拟机安装ARM win11的方法  CSS Grid如何控制元素对齐_align-items与justify-items组合使用  如何在低配置电脑上搭建轻量级J*a环境_占用更小的环境选择技巧  在J*a中如何开发简易仓库管理与库存统计_仓库管理库存统计项目实战解析 

搜索