<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>原生js制作二级菜单</title> <style> *{ margin:0; padding:0; } #nav{ width: 800px; height: 50px; line-height: 50px; margin: 20px auto; background-color: darkcyan; } ul,ol,li{ list-style: none; } #nav>ul>li{ width: 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; width: 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 标签