JS 多级菜单的功能添加

JavaScript026

JS 多级菜单的功能添加,第1张

<script type="text/javascript">

var outName=""

window.onload=function(){

var len = document.getElementsByTagName('a').length

for(var i=0i<leni++)

{

document.getElementsByTagName('a')[i].id='a'+i

document.getElementsByTagName('a')[i].onclick=function(){

outName=Number(this.id.substring(1,this.id.length))

}

}

}

function appendLi(){

var ttt = document.getElementById('ttt').value

var ul = document.createElement('ul')

var li = document.createElement('li')

li.innerHTML=ttt

ul.appendChild(li)

document.getElementById('a'+outName).parentElement.appendChild(ul)

}

</script>

</head>

<body>

<div class="container">

<ul style="display: block">

<li><a href="#" style="font-size: 12px padding-left: 10px">人事管理</a></li>

<li><a href="#" style="font-size: 12px padding-left: 10px">部门管理</a></li>

<li><a href="#" style="font-size: 12px padding-left: 10px">考勤管理</a></li>

</ul>

</div>

<label>

<input type="checkbox" value="" />根目录</label>

<label><br>

<input id="ttt" type="text" value="" /><input type="button" value="添加" onclick="appendLi()"/></label>

</body>

除了html代码<a></a>没有关闭  你的逻辑有点乱

htm导航栏是

<li><a href="" ></a></li><!--a标签要关闭 -->

<li><a href="></a></li><!--a标签要关闭 -->

<li>

    <a href="></a>  <!--a标签要关闭 -->

   <div class="nav-list" id="dataTd" style="display: none">

       <a href=“">人物角色</a>

       <a href="">游戏视频</a>

   </div>  

</li>

html文件中有id为dataTd但是没有dataTh

js是

<script type="text/javascript">

    var oDiv1=document.getElementById('dataTh')

    //获取ID 为dataTh的html元素

    var oDiv2=document.getElementById('dataTd')

    //获取ID 为dataTd的html元素

     var timer=null

//onmouseover代表鼠标划入指定范围  触发事件

      oDiv2.onmouseover=oDiv1.onmouseover=function ()

    {

        clearTimeout(timer)

        oDiv2.style.display='block'

        oDiv1.className='data-list'

这几句代码的意思是  当鼠标指向id为dataTh或者id为dataTd的元素,触发id为dataTd的元素显示,id为dataTh的元素添加类名为“data-list”的class类

    }

//onmouseout代表鼠标离开指定范围  触发事件

    oDiv2.onmouseout=oDiv1.onmouseout=function ()

    {

        timer=setTimeout(function (){

            oDiv2.style.display='none'id为dataTd的元素隐藏

            oDiv1.className=''id为dataTh的元素去掉类名为“data-list”的class类

        }, 100)

每0.1秒执行一次

    }

</script>

我给你举个例子

要实现的功能是  当鼠标划过列表中的id="dataTh"的元素时,隐藏的子菜单显示

html页面

<li>

    <a href=" id="dataTh"></a>  

<!--子菜单  以下处于隐藏状态 -->

    <div class="nav-list" id="dataTd" style="display: none">

       <a href=“">人物角色</a>

       <a href="">游戏视频</a>

    </div>  

<!--子菜单  以上处于隐藏状态 -->

</li>

JS

<script type="text/javascript">

    var oDiv1=document.getElementById('dataTh')

    //获取ID 为dataTh的html元素

    var oDiv2=document.getElementById('dataTd')

    //获取ID 为dataTd的html元素

     var timer=null

//onmouseover代表鼠标划入指定范围  触发事件

    oDiv1.onmouseover=function ()

    {

        clearTimeout(timer)

        oDiv2.style.display='block'

        oDiv1.className='data-list'

//这几句代码的意思是  当鼠标指向id为dataTh的元素,触发id为dataTd的元素显示,id为dataTh的元素添加类名为“data-list”的class类

    }

//onmouseout代表鼠标离开指定范围  触发事件

    oDiv1.onmouseout=function ()

    {

        oDiv2.style.display='none'//id为dataTd的元素隐藏

        oDiv1.className=''//id为dataTh的元素去掉类名为“data-list”的class类

    }

</script>

!DOCTYPE html>

<html>

<head lang="en">

<meta charset="UTF-8">

<title></title>

<script type="text/javascript">

//显示角色详细信息

function showDetail(flag, a) {

var detailDiv = a.parentNode.getElementsByClassName('detail_info')[0]

if (flag) {

detailDiv.style.display = "block"

}

else

detailDiv.style.display = "none"

}

</script>

<script src="../assets/jquery.js"></script>

</head>

<body>

<input type ="button" va