html+css+js实现导航栏色块跟随滑动

这段代码展示了如何使用CSS和JavaScript创建一个动态导航栏,当鼠标经过导航项时,背景色会平滑地向对应位置滑动。主要涉及到CSS的布局、样式设置以及JavaScript事件监听和定时器应用。
摘要由CSDN通过智能技术生成

css样式

<style>
        * {
            margin: 0px;
            padding: 0px;
        }

        ul {
            list-style: none;
        }

        html,
        body {
            height: 100%;
            width: 100%;
            background: black;
        }

        a {
            text-decoration: none;
        }

        ul {
            position: relative;
            background: #fff;
            overflow: hidden;
            width: 900px;
            margin: 50px auto;
            padding: 20px 0px;
            display: flex;
            border-radius: 5px;
        }

        ul li {
            position: relative;
            z-index: 10;
            flex: 1;
            text-align: center;
        }

        ul li a {
            font-size: 18px;
            color: #333;
        }

        .bg {
            width: 83px;
            height: 42px;
            display: inline-block;
            background-color: red;
            position: absolute;
            left: 34px;
            top: 0px;
            bottom: 0px;
            margin: auto;
            z-index: 2;
        }
    </style>

body

<body>
    <ul>
        <span class="bg"></span>
        <li>
            <a href="javascript:;">首页</a>
        </li>
        <li>
            <a href="javascript:;">电视剧</a>
        </li>
        <li>
            <a href="javascript:;">新电影</a>
        </li>
        <li>
            <a href="javascript:;">新闻</a>
        </li>
        <li>
            <a href="javascript:;">娱乐</a>
        </li>
        <li>
            <a href="javascript:;">军事</a>
        </li>
    </ul>
    <script>
        // 需求:鼠标经过哪个导航栏目,背景色滑动过去  
        var liList = document.getElementsByTagName('li');
        var bg = document.getElementsByClassName('bg')[0];
        var header = 34;
        var liLeft = 34;
        console.log(34);

        // 添加事件
        // 遍历li 
        for (var i = 0; i < liList.length; i++) {
            liList[i].onmouseover = function () {
                liLeft = this.offsetLeft + (this.offsetWidth - bg.offsetWidth) / 2;
            }
        }

        // 使用定时器
        setInterval(function () {
            header = header + (liLeft - header) / 10;
            bg.style.left = header + 'px';
        }, 10)
    </script>
</body>

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值