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

实现导航栏下划线过渡效果,关键在于利用伪元素和CSS的transform与transition属性。这种方式既美观又性能良好。
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;
bo
ttom: 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中如何开发简易仓库管理与库存统计_仓库管理库存统计项目实战解析


2025-10-27
浏览次数:次
返回列表
ttom: 0;
width: 0;
height: 2px;
background-color: #007bff;
transition: width 0.3s ease;
}
.n*-link:hover::after {
width: 100%;
}