javascript下拉列表菜单的实现方法
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript下拉列表菜单的实现方法,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含4215字,纯文字阅读大概需要7分钟。
内容图文
![javascript下拉列表菜单的实现方法](/upload/InfoBanner/zyjiaocheng/356/6faca23be47b4427bbc44d3e90838beb.jpg)
之前写过这个《javascript下拉列表中显示树形菜单的实现方法》菜单的体现,但是在写了之后就发现了,不太适合,高度要精准控制,并且还不是很好看。现在采用table来封装,我们知道table的每一行写满了之后,下一行会自动加,这个比之前我们自己制定高度好很多。
1、点击之后都可以并存的情况(只需函数写法不一样就可)
dispaly也是自己设置的,通过父节点来操作子节点,显示与否;
/* function open1(node){ //通过父节点来操作兄弟节点 当点击之后出现之后,直接就能打开但是要求在点开一个时候,其余的都关掉 var nodes = node.parentNode; var nn = nodes.getElementsByTagName("ul")[0]; with (nn.style) { display = (display == "block") ? "none" : "block"; } }*/ </script>
2、点击之后只允许打开一个,其余的都要关掉
<script type="text/javascript"> function list1(node){ //这是要对全部操作,必须要得到所有的对象 (根据table 的id 来获得) //根据this判断,不是属于this,那么就关闭 //alert("aa"); //1,获得点击对象的值 var nodes = node.parentNode;//传入当前的父节点 var nn = nodes.getElementsByTagName("ul")[0];//得到当前的对象,要是遍历所有,与这个对象一样,就设置相反的情况,其余的全部关闭 //2,获得全部对象 var mm = document.getElementById("menuid"); var names = mm.getElementsByTagName("ul"); //3,开始一一配对 for (var x = 0; x < names.length; x++) { /*这样写,可以简化,利用下面的方法 if (names[x] == nn) { if (nn.className == "open2") { nn.className = "close2"; } else { nn.className = "open2"; } }else { nn.className = "close2"; }*/ if(names[x]==nn&&names[x].className!="open2"){ nn.className="open2"; }else{ names[x].className="close2"; } } } </script>
css样式的编写:
<style type="text/css"> ul{ list-style:none; margin:0px; padding:0px; } table{ border:#00ff40 solid 1px; } table a{ text-decoration:none; } table tr td ul{ display:none; } .open2{ display:block; background:#8080ff; } .close2{ display:none; }
效果图(只能开一个的):
完整代码:
<!DOCTYPE html> <html> <head> <title>qqMenu.html</title> <style type="text/css"> ul{ list-style:none; margin:0px; padding:0px; } table{ border:#00ff40 solid 1px; } table a{ text-decoration:none; } table tr td ul{ display:none; } .open2{ display:block; background:#8080ff; } .close2{ display:none; } </style> <script type="text/javascript"> /* function open1(node){ //通过父节点来操作兄弟节点 当点击之后出现之后,直接就能打开但是要求在点开一个时候,其余的都关掉 var nodes = node.parentNode; var nn = nodes.getElementsByTagName("ul")[0]; with (nn.style) { display = (display == "block") ? "none" : "block"; } }*/ </script> <script type="text/javascript"> function list1(node){ //这是要对全部操作,必须要得到所有的对象 (根据table 的id 来获得) //根据this判断,不是属于this,那么就关闭 //alert("aa"); //1,获得点击对象的值 var nodes = node.parentNode;//传入当前的父节点 var nn = nodes.getElementsByTagName("ul")[0];//得到当前的对象,要是遍历所有,与这个对象一样,就设置相反的情况,其余的全部关闭 //2,获得全部对象 var mm = document.getElementById("menuid"); var names = mm.getElementsByTagName("ul"); //3,开始一一配对 for (var x = 0; x < names.length; x++) { /*这样写,可以简化,利用下面的方法 if (names[x] == nn) { if (nn.className == "open2") { nn.className = "close2"; } else { nn.className = "open2"; } }else { nn.className = "close2"; }*/ if(names[x]==nn&&names[x].className!="open2"){ nn.className="open2"; }else{ names[x].className="close2"; } } } </script> <!--<link rel="stylesheet" type="text/css" href="./styles.css">--> </head> <body > <table id="menuid"> <tr> <td> <!--<a href="javascript:void(0)" onclick="open1(this)">同事栏</a>--> <a href="javascript:void(0)" onclick="list1(this)">同事栏</a> <ul > <li>同事1</li> <li>同事2</li> <li>同事3</li> <li>同事4</li> </ul> </td> </tr> <tr> <td> <!--<a href="javascript:void(0)" onclick="open1(this)">同学栏</a>--> <a href="javascript:void(0)" onclick="list1(this)">同学栏</a> <ul> <li>同学1</li> <li>同学2</li> <li>同学3</li> <li>同学4</li> </ul> </td> </tr> <tr> <td> <!--<a href="javascript:void(0)" onclick="open1(this)">黑名单栏</a>--> <a href="javascript:void(0)" onclick="list1(this)">黑名单栏</a> <ul> <li>黑名单同学1</li> <li>黑名单同学2</li> <li>黑名单同学3</li> <li>黑名单同学4</li> </ul> </td> </tr> </table> </body> </html>
相信大家通过这两篇文章的介绍应该有了大概的思路,小编的这篇文章有些制作的效果略微简陋,大家可以再进一步的完善。
内容总结
以上是互联网集市为您收集整理的javascript下拉列表菜单的实现方法全部内容,希望文章能够帮你解决javascript下拉列表菜单的实现方法所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。