当前位置:首页 > html教程 > 正文内容

css如何实现流程导航效果?有哪几种方法?_html5教程,css,流程导航效果

搜教程4年前 (2020-03-07)html教程159

方法一:利用裁剪(该方法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>

(相关教程推荐:CSS入门教程)

方法二:利用错位

<!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>

更多编程相关教程,请关注ki4网编程入门栏目!

以上就是css如何实现流程导航效果?有哪几种方法?的详细内容,更多请关注ki4网其它相关文章!

扫描二维码推送至手机访问。

版权声明:本文由搜教程网发布,如需转载请注明出处。

本文链接:https://www.sojiaocheng.cn/17343.html

分享给朋友:

“css如何实现流程导航效果?有哪几种方法?_html5教程,css,流程导航效果” 的相关文章

CSS制造一个三角的导航提醒结果(代码实例)【html5教程】,三角的导航提示,CSS制作

CSS制造一个三角的导航提醒结果(代码实例)【html5教程】,三角的导航提示,CSS制作

本篇文章给人人带来的内容是关于CSS制造一个三角的导航提醒结果,有肯定的参考价值,有须要的朋侪能够参考一下,愿望对你有所协助。 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.or...

CSS filter:hue-rotate色彩扭转滤镜完成按钮批量生产【html5教程】,filter:hue-rotate色调旋转,滤镜实现

CSS filter:hue-rotate色彩扭转滤镜完成按钮批量生产【html5教程】,filter:hue-rotate色调旋转,滤镜实现

本篇文章给人人带来的内容是关于CSS filter:hue-rotate颜色扭转滤镜完成按钮批量生产,有肯定的参考价值,有须要的朋侪能够参考一下,愿望对你有所协助。 //zxx: 许多效果为CSS3滤镜及时衬着,因而本文须要在Chrome等当代阅读器下阅读 一、传统色值按钮 传统按钮都是经...

CSS3怎样完成反复径向渐变结果【html5教程】,CSS3实现重复径向渐变效果

CSS3怎样完成反复径向渐变结果【html5教程】,CSS3实现重复径向渐变效果

css3中的渐变结果,包含线性渐变、径向渐变、反复线性渐变以及反复径向渐变。这些渐变结果,可以使我们的网页内容越发雄厚炫彩。 引荐进修:《CSS3教程》 那末在前面的文章中,我们已给人人引见了css3完成线性渐变结果、径向渐变结果以及反复线性渐变结果。 下面我就连系简朴的示例继承给...

css计数器怎样完成自动嵌套编号【html5教程】,css,计数器,自动编号

css计数器怎样完成自动嵌套编号【html5教程】,css,计数器,自动编号

在css中能够运用计数器函数counter()和counters()合营content属性来离别完成给元素自动嵌套编号的结果,下面我们就来看看CSS计数器函数counter()和counters()是怎样自动嵌套编号的。 css计数器运用多个counter()函数嵌套编号 css计数器的...

css怎样完成牢固的背景图象【html5教程】,css固定背景图像

css怎样完成牢固的背景图象【html5教程】,css固定背景图像

所谓牢固背景图象,就是当我们在页面输入任何内容时或许挪动鼠标,背景图象都不会发作更改。css完成背景图象牢固也是异常简朴的,我们能够运用css中的background的相干属性来完成。 引荐参考:《CSS教程》 那末我们在前面的文章中有给人人引见过CSS怎样完成背景图象反复结果。...

css边框款式有若干种【html5教程】,css边框样式

css边框款式有若干种【html5教程】,css边框样式

多样的边框款式,能够雄厚我们网页的界面,进步用户体验。css边框款式,罕见的有实线、虚线、双线、点线等等一些边框款式。 下面我们就给经由过程简朴的代码示例,给人人总结一些罕见的边框款式! 代码以下: <!DOCTYPE> <html> <meta char...