CSS实现流程导航的方式有几种
Admin 2022-05-23 群英技术资讯 502 次浏览
css实现流程导航效果,具体内容如下所示:
::tip 使用纯css线上 流程导航效果。 本文统一采取 flex 布局 ,你也可以采用其他布局实现,核心原理不变 :::
## 方法一 利用裁剪 该方法IE下不支持
利用裁剪 clip-path: polygon(),直接画出一个三角 唯一一点需要算出大致百分比就可以画出来
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width"> <style> .nav-box { display: flex; list-style: none; font-size: 14px; } .nav-box li { white-space: nowrap; color: #019fe9; background: #edf9ff; counter-increment: listCounter; clip-path: polygon(87% 0, 100% 50%, 87% 100%, 0 100%, 13% 50%, 0 0); line-height: 40px; padding: 0 25px; margin-right: -10px; } .nav-box li::before { content: counter(listCounter) "-"; } .nav-box .active { color: #fcfefe; background: #009fe9; } .nav-box .active ~ li { color: #8e8e8e; background: #ebedf0; } </style> </head> <body> <!-- 容器 --> <ol class="nav-box"> <li><a href="">规则说明</a></li> <li><a href="">参与活动</a></li> <li class="active" aria-current="true"><a href="">参与抽奖</a></li> <li><a href="">奖品发放</a></li> <li><a href="">查看结果</a></li> </ol> </body> </html>
## 方法二 利用错位
flex + transform : skewX(); 实现 ie9+ 状况下使用前缀 -ms- + 这个方法也完全利用里before after, + 原理1 --- 利用 before + after 分成上下半区 <Badge text="【这种方法有个缺陷就是要单独补全第一个的尾巴】" type="warn"/> + 原理2 --- 利用 before + after 分成左右半区 <Badge text="【该方法只对第一个before 或 after做处理避免第一个的问题】" type="success"/>
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width"> <style scoped> .nav-box { display: flex; list-style: none; font-size: 14px; } .nav-box li { white-space: nowrap; color: #019fe9; padding: 0 15px 0 25px; line-height: 40px; margin-left: 3px; position: relative; z-index: 99; } .nav-box li:first-child{ background: #edf9ff; margin-right: 7px; } .nav-box .active:first-child{ background: #019fe9; } .nav-box li:first-child::before, .nav-box li:first-child::after{ left: 7px; } .nav-box li::before, .nav-box li::after { content: ""; position: absolute; left: 0; height: 50%; width: 100%; background: #edf9ff; z-index: -1; } .nav-box li::before { top: 0; transform: skew(30deg); } .nav-box li::after { bottom: 0; transform: skew(-30deg); } .nav-box .active { color: #d7effb; } .nav-box .active::before, .nav-box .active::after { background: #009fe9; } .active ~ li { color: #909091; } .active ~ li::before, .active ~ li::after { background: #ebedf0; } </style> </head> <body> <!-- 容器 --> <ol class="nav-box"> <li class="active">1-规则说明</li> <li>2-参与活动</li> <li>3-参与抽奖</li> <li>4-奖品发放</li> <li>5-参与结果</li> </ol> </body> </html>
## 方法三 border造三角
利用 border 生成前后三角 缺点是索引需要自己定义 不加标签情况下无法使用css计数器
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width"> <style> .nav-box{ height:40px; line-height:40px; list-style: none; padding:0; display:flex; font-size:14px; overflow: hidden; } .nav-box li{ padding:0 10px 0 10px; margin-right: 18px; white-space: nowrap; position:relative; color:#019fe9; background:#edf9ff ; } /* 三角 */ .nav-box li:before,.nav-box li:after{ content:''; position:absolute; width: 0; height: 0; } .nav-box li:before{ right: -16px; border: solid transparent; border-width: 20px 0 20px 16px; border-left-color:#edf9ff; z-index:2; } /* 白线 */ .nav-box li:after{ top: -3px; left: -18px; border: solid #edf9ff; border-width: 23px 0 23px 18px; border-left-color: transparent; z-index: 1; } .nav-box .active{ color: #fff; background:#009fe9; } .nav-box .active ~ li{ color:#8e8e8e; background:#ebedf0; } .nav-box .active:before{ border-left-color:#009fe9; } .nav-box .active:after{ border-color: #009fe9; border-left-color: transparent; } .nav-box .active ~ li:before{ border-left-color:#ebedf0; } .nav-box .active ~ li:after{ border-color: #ebedf0; border-left-color: transparent; } </style> </head> <body> <ol class="nav-box"> <li>1-规则说明</li> <li>2-参与活动</li> <li class="active">3-参与抽奖</li> <li>4-奖品发放</li> <li>5-参与结果</li> </ol> </body> </html>
总结
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了结合 CSS3 transition transform 实现简单的跑马灯效果的示例的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
我们先理理思路,大家想一想,梯形是怎么构成的,小学的数学课本都讲过的,就拿等腰梯形来说, 是由两个直角三角形,和一个长方形或正方形组成的,看草图↓ 这意味着,我们要用一个&
在css中,可以利用“box-shadow”属性来设置元素边框右边和下边的阴影,该属性的作用是设置元素的边框阴影样式,语法为“元素{box-shadow:向右阴影值 向下阴影值 blur spread color ;}”。
我们在编写代码的时候是不是都会发现浏览器中有浮动呢?那么你知道css要怎么清除浮动吗?一些朋友可能会遇到这方面的问题,对此在下文小编向大家来讲解一下,内容详细,易于理解,希望大家阅读完这篇能有收获哦,有需要的朋友就往下看吧!
这篇文章主要介绍了CSS清除图片下几像素空白间隙的方法 ,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008