zoukankan      html  css  js  c++  java
  • 原生js实现二级导航功能

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>原生js制作二级菜单</title>
        <style>
            *{
                margin:0;
                padding:0;
            }
            #nav{
                 800px;
                height: 50px;
                line-height: 50px;
                margin: 20px auto;
                background-color: darkcyan;
            }
            ul,ol,li{
                list-style: none;
            }
            #nav>ul>li{
                 160px;
                text-align: center;
                float: left;
                list-style: none;
            }
            a{
                text-decoration: none;
                color: #000;
            }
            a:hover{
                text-decoration: underline;
                color: #fff;
            }
            .companyIntroduceUrl{
                display: none;
                 100px;
                margin: 0 auto;
                background-color: lightsteelblue;
            }
            .companyIntroduceUrl>li{
                padding:0;
                margin:0;
            }
        </style>
    </head>
    <body>
    <div id="nav">
        <ul>
            <li><a href="#">首页</a></li>
            <li onmouseover="onOver(this)" onmouseout="onOut(this)">
                <a href="#">公司介绍</a>
                <ul class="companyIntroduceUrl">
                    <li><a href="#">走进我们</a></li>
                    <li><a href="#">悠久历史</a></li>
                    <li><a href="#">公司理念</a></li>
                    <li><a href="#">经理致辞</a></li>
                </ul>
            </li>
            <li><a href="#">产品展示</a></li>
            <li><a href="#">联系我们</a></li>
            <li><a href="#">招贤纳士</a></li>
        </ul>
    </div>
    
    
    <script src="js/jquery-3.2.1.min.js"></script>
    <script>
    
            function onOver(obj){
                var sub_url=obj.getElementsByTagName("ul")
                sub_url[0].style.display="block";
            }
            function onOut(obj){
                var sub_url=obj.getElementsByTagName("ul")
                sub_url[0].style.display="none";
            }
    
    </script>
    
    
    </body>
    </html>
    

     二级菜单的机构特点

      二级菜单的结构可以有很多种形式,在本例种采用了<ul>与<li>标签相结合的方式进行布局,二级菜单的<ul>放在对应的一级菜单<li>标签里。这是一种比较简单明了的结构。二级菜单与一级菜单相互对应,相互结合,让程序员一目了然。

    二级菜单的样式特点

      二级菜单的出现不能影响到其他的标签,因此二级菜单<ul>标签只能是“绝对定位”的。要“管住”二级菜单,一级菜单的<li>标签就只有“相对定位”。这是css样式中绝对定位与相对定位的经典应用。

    getElementsByTagName()函数

      getElementsByTagName()函数的字面意思是"通过标签名字获取标签",函数括号里必须是HTML标签的名称。需要注意的是getElementsByTagName函数名字里有个"s",说明它获取的标签可能不止一个。实际上,它获取的是一个标签的数组,会把制定范围里的所有同名标签都获取到。

      getElementsByTagName的制定范围完全是由它前面的对象决定的。

      它前面的对象常常有两种:

      var xy=document.getElementsByTagName("div");

      获取页面(document)里面所有的<div>标签,并装载在变量xy中。

      在它获取的众多标签中,每个标签都有自己的编号。按照在HTML里出现的顺序,依次是0,1,2...通过类似xy[0]的格式来获取某个具体的标签。

      或者

      var x=document.getElementById("big");

      var z=x.getElementByTagName("div");

      表示的是 z 获的是 x 下所有的 div 标签

      

  • 相关阅读:
    缺失值的常见填充方法
    多变量线性回归
    回归(补充)
    单变量线性回归
    监督学习和非监督学习
    Java学习-数组(1)
    如何发布一个npm包(基于vue)
    《麦肯锡教给我的写作武器》摘录
    自定义博客样式
    ubuntu 下配置elasticSearch
  • 原文地址:https://www.cnblogs.com/yingleiming/p/7799956.html
Copyright © 2011-2022 走看看