练手小案例:用js实现二级导航

使用HTML5+CSS3+JS实现简单的二级导航,绝对的干货!

效果图:

HTML部分:

    <!-- 导航 -->
    <nav class="pageNav">
        <ul class="navUl">
            <li><a href="#">首页</a></li>
            <li>
                <a href="#">公司介绍</a>
                <ul class="erji">
                    <li><a href="#">二级菜单</a></li>
                    <li><a href="#">二级菜单</a></li>
                    <li><a href="#">二级菜单</a></li>
                </ul>
            </li>
            <li>
                <a href="#">产品展示</a>
                <ul class="erji">
                    <li><a href="#">二级菜单</a></li>
                    <li><a href="#">二级菜单</a></li>
                    <li><a href="#">二级菜单</a></li>
                </ul>
            </li>
            <li>
                <a href="#">企业荣誉</a>
                <ul class="erji">
                    <li><a href="#">二级菜单</a></li>
                    <li><a href="#">二级菜单</a></li>
                    <li><a href="#">二级菜单</a></li>
                </ul>
            </li>
        </ul>
    </nav>
    <!-- 导航 end -->

 CSS部分:

*{
    padding: 0;
    margin: 0;
}
ul,li,ol{
    list-style: none;
}
a{
    text-decoration: none; 
}
.pageNav{
    width: 560px;
    height: 60px;
    margin-right: auto;
    margin-left: auto;
    background-color: #09f;
}
.navUl{
    display: flex;
}
.navUl>li{
    position: relative;
}
.navUl>li>a{
    display: block;
    width: 140px;
    height: 50px;
    color: white;
    text-align: center;
    font-size: 25px;
    padding-top: 10px;
    transition: all 0.5s;
}
.navUl>li>a:hover{
    background-color: orange;
}
.erji{
    width: 100%;
    height: 100px;
    position: absolute;
    display: none;
}
.erji>li>a{
    display: block;
    color: black;
    text-align: center;
    line-height: 33px;
    background-color: #96cdff;
}
.erji>li>a:hover{
    background-color: orange;
    color: white;
}

JavaScript部分:

let li = document.querySelectorAll(".navUl > li");
for(let i = 0; i <= li.length-1; i++){
    li[i].addEventListener("mouseenter",function(){
        let erji = this.children[1];
        if(!erji){
            return false;
        }
        erji.style.display = "block";
    });
    li[i].addEventListener("mouseleave",function(){
        let erji = this.children[1];
        if(!erji){
            return false;
        }
        erji.style.display = "none";
    });
}

学会了记得点赞哦!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值