zoukankan      html  css  js  c++  java
  • JS写的二级导航栏(利用冒泡原理)

    今天给大家分享一种用JS写的导航栏,虽然我们工作中不会使用JS来做导航栏,为了练习我们用JS来做一个JS导航栏
    这种方法要比其他方法代码量少很多,但是需要对事件冒泡有一定的理解,如果需要理解冒泡可以参考一下,
    该注释的地方我都给大家注释上了
     
    思路:给所有的 li 加上 鼠标移入事件当鼠标移入时会触发事件,由于事件的冒泡机制,每次二级导航栏里的事件触发时同时会触发父级 li 的事件
       调试时可以用e.stopPropagation()阻止事件冒泡来看看冒泡和不冒泡的区别
     
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <style>
            *{margin:0;padding:0;}
            ul,li{list-style: none;}
            /* 一级导航样式 */
            #nav{
                100%;
                height: 40px;
                background: #000;
            }

            #nav>li{
                float: left;
                position: relative;
            }
            #nav>li>a{
                float: left;
                 80px;
                height: 40px;
                color: #fff;
                text-decoration: none;
                line-height: 40px;
                text-align: center;
            }
            
            #nav li>.active{
                background: yellow;
            }
            #nav>li>ul>li>.active{
                background: red;
            }
            #nav>li>ul{
                 100px;
                background: #000;
                position: absolute;
                left: 0;
                top: 40px;
                display: none;
            }

            #nav>li>ul>li>a{
                text-decoration: none;
                color: #fff;
                line-height: 30px;
                text-align: center;
                 100px;
                height: 30px;
                display: block;
            }
        </style>
    </head>
    <body>
        <ul id="nav">
            <li>
                <a href="##">首页</a>
                <ul >
                    <li><a href="##">首页1</a></li>
                    <li><a href="##">首页1</a></li>
                    <li><a href="##">首页1</a></li>
                    <li><a href="##">首页1</a></li>
                    <li><a href="##">首页1</a></li>
                </ul>
            </li>
            <li>
                <a href="##">文档</a>
                <ul>
                    <li><a href="##">文档1</a></li>
                    <li><a href="##">文档1</a></li>
                    <li><a href="##">文档1</a></li>
                    <li><a href="##">文档1</a></li>
                    <li><a href="##">文档1</a></li>
                </ul>
            </li>
            <li>
                <a href="##">我的</a>
                <ul>
                    <li><a href="##">我的1</a></li>
                    <li><a href="##">我的1</a></li>
                    <li><a href="##">我的1</a></li>
                    <li><a href="##">我的1</a></li>
                    <li><a href="##">我的1</a></li>
                </ul>
            </li>
        </ul>
    </body>
    </html>
    <script>
    //先获取父级元素
    var oNav = document.getElementById("nav"); 
    //获取导航栏中所有的li
    var aLi = oNav.querySelectorAll("li");
    //鼠标移入二级导航出现 
    for(var i=0;i<aLi.length;i++){
        //给每一个li添加一个鼠标移入事件(主要应用冒泡的原理,但是效率可能有点低)
        aLi[i].onmouseover = function() {
             //给a标签添加active
             var a = this.children[0];
             a.className ="active";
     
             //将二级导航显示
             //获取ul 判断是否存在ul,若存在则显示ul
             var ul = this.children[1];       
             if(ul){
             ul.style.display = "block";} 
          //e.stopPropagation()在此将事件冒泡阻止试试
        }

        //鼠标移出的时候将a标签的颜色移除
        aLi[i].onmouseout = function() {
             //给a标签去除active
             var a = this.children[0];
             a.className ="";
             //将二级导航隐藏
             var ul = this.children[1];
             if(ul){    // if(ul)表示存在ul这个东西
                ul.style.display = "none";
                 console.log(111);
             }
        }
    }
    </script>
  • 相关阅读:
    回顾2011,展望我的2012
    查看MS SQL SERVER数据库中表的大小
    MS SQL SERVER数字格式化显示,每三位加逗号
    MS SQL Server 保留一行,清除多余冗余数据
    ASP.NET Webform和ASP.NET MVC的区别
    Firefox的刷新功能与Safari,IE的差距
    TIOBE如何计算编程语言的排行?
    如何让ComboBox的下拉列表宽度自适应内容的宽度
    如何启用.NET中的Fusion Log
    JavaScript的clone函数的实现及应用条件
  • 原文地址:https://www.cnblogs.com/suihang/p/9522027.html
Copyright © 2011-2022 走看看