CSS滑动跟踪导航栏

1 展示

在这里插入图片描述点击前往在线展示

2 代码

2.1 HTML

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>滑动跟踪导航栏</title>
    <link rel="stylesheet" href="./nav.css">
</head>
<body>
    <div class="nav">
        <ul>
            <li><a href="#">HTML</a></li>
            <li><a href="#">CSS</a></li>
            <li><a href="#">JS</a></li>
            <li><a href="#">Jquery</a></li>
            <li><a href="#">VUE</a></li>
            <li><a href="#">PHP</a></li>
            <div class="nav-box"></div>
           
        </ul>
    </div>
</body>
</html>

2.2CSS

*{
    list-style: none;
    padding: 0;
    margin: 0;
    text-decoration: none;
}

body{
    display: flex;
    justify-content: center;
    align-items:center;
    height: 100vh;
    background-color: #8da1f8;
}

.nav{
    width: 1200px;
    height: 70px;
    position: relative;
    top: 0;
    box-shadow: 0 5px 20px rgba(0,0,0,.5);
    border-radius: 10px;
    background-color: #fff;
}

.nav ul{
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    right: 5%;
}

.nav ul .nav-box{
    position: absolute;
    bottom: 0;
    left: 0;
    /* 如果导航栏就六个导航,那么每个导航的宽度都是整个导航的六分之一 */
    width: calc((100%/6)*1);
    height: 10px;
    border-radius: 2px;
    transition: .5s;
}

.nav ul li{
    width: 100%;
    text-align: center;
}

.nav ul li a{
    color: rgb(70, 100, 180);
    font: 100 30px '';
    display: block;
    width: 100%;
    height: 100%;
    line-height: 70px;
}

.nav ul li:nth-child(1):hover~.nav-box{
    left: calc((100%/6)*0);
    background-color: rgb(250, 190, 250);
}
.nav ul li:nth-child(2):hover~.nav-box{ 
    left: calc((100%/6)*1);
    background-color: red;
}
.nav ul li:nth-child(3):hover~.nav-box{ 
    left: calc((100%/6)*2);
    background-color: #d18df8;
}
.nav ul li:nth-child(4):hover~.nav-box{ 
    left: calc((100%/6)*3);
    background-color: #ffb1b1;
}
.nav ul li:nth-child(5):hover~.nav-box{ 
    left: calc((100%/6)*4);
    background-color: #8da1f8;
}
.nav ul li:nth-child(6):hover~.nav-box{ 
    left: calc((100%/6)*5);
    background-color: #7df88e;
}

3 部分解释

3.1 hover的简单介绍(+,~的用法)

注意hover后面一帮都是控制子元素
hover更改同级(兄弟)元素属性:
更改兄弟元素又分两种情况:
(1)需要更改的兄弟元素是当前元素的相邻元素,也就是说紧接着当前元素。那么写法如下:

.item-1:hover +.item-2{
    background-color:#50ff00;
}

(2)需要改变的兄弟元素不是当前元素的邻接元素(如上面演示图中的 item-1 和 item-3)。
这种情况就需要改一下写法,用上面的 “+” 就行不通了,得用 “~”。写法如下:

.item-1:hover ~.item-3>.item-3-child{
    background-color:#50ff00;
}
  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
您好,如果您想在uni-app中使用导航栏,可以使用uni-app提供的自定义导航栏功能来实现。下面是一个简单的导航栏实现示例: 1. 在页面的顶部添加一个view,宽度和高度与屏幕宽度相同,高度为状态栏高度+导航栏高度,设置其position为fixed,top为0,left为0,background-color为导航栏的背景色。 2. 在这个view中添加两个子view,一个用于显示标题,另一个用于显示左侧返回按钮。左侧返回按钮可以使用uni-icons组件中的返回图标,或者使用自定义的图标。 3. 可以在每个页面中单独引入这个导航栏组件,在需要的页面中进行调用即可。 下面是一个示例代码,供您参考: ```html <template> <view> <!-- 自定义导航栏 --> <view class="navbar"> <view class="left" @click="goBack"> <uni-icons type="back"></uni-icons> </view> <view class="title">{{ title }}</view> </view> <!-- 页面内容 --> <view class="content"> <view>这里是页面内容</view> </view> </view> </template> <script> export default { data() { return { title: '页面标题' } }, methods: { goBack() { uni.navigateBack({ delta: 1 }) } } } </script> <style> .navbar { position: fixed; top: 0; left: 0; width: 100%; height: 88rpx; line-height: 88rpx; background-color: #fff; border-bottom: 1px solid #e5e5e5; z-index: 999; } .left { position: absolute; top: 0; left: 0; width: 88rpx; height: 88rpx; text-align: center; font-size: 32rpx; } .title { margin: 0 auto; font-size: 36rpx; text-align: center; max-width: 600rpx; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; } .content { padding-top: 88rpx; min-height: calc(100vh - 88rpx); } </style> ``` 在上面的代码中,我们定义了一个名为navbar的view,用于显示导航栏。其中,left子view用于显示返回按钮,title子view用于显示标题。在goBack方法中,我们使用uni.navigateBack方法实现了返回上一页的功能。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

GT-一二

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值