简单实现js点击展开二级菜单功能
虽然,jQuery已经非常好用了,但是实际的开发项目中,还是有很多限制,比如项目组奇葩的要求,不能使用任何插件,当然,也是考虑插件占用资源,毕竟100+KB对与小型项目来说还是非常大的。我最近就遇到做个点击展开二级菜单的要求,当然只能用原生的JS去写来实现,我借鉴了网上的一个案例,补充一下,分享一下:
如果,默认打开页面进来时二级菜单是隐藏的,需要点击才能展现二级菜单,再点击就是隐藏二级菜单。这里有两个点,实现展现和隐藏用display="block"和display="none",另外就是要做一个判断,if else的判断当前是block还是none。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style type="text/css"> #sub_menu_1,#sub_menu_2{ display: none; } ul li:hover{ cursor: pointer; } </style> </head> <body> <ul> <li onclick = "f('sub_menu_1')">一级菜单1 <ul id="sub_menu_1"> <li>二级餐单1</li> <li>二级餐单1</li> <li>二级餐单1</li> <li>二级餐单1</li> </ul> </li> <li onclick="f('sub_menu_2')">一级菜单2 <ul id="sub_menu_2"> <li>二级菜单2</li> <li>二级菜单2</li> <li>二级菜单2</li> <li>二级菜单2</li> </ul> </li> <li>一级餐单3</li> </ul> <script type="text/javascript"> function f(str){ var sub_menu = document.getElementById(str); var dis_v = sub_menu.style.display; if(dis_v == "block") sub_menu.style.display = "none"; else sub_menu.style.display = "block"; } </script> </body> </html>
有个注意事项就是一级菜单的li不能添加a标签,不然会不起作用。 如果,你的页面默认进来二级菜单是展现的,点击时才关闭。直接把style标签的样式display="none"去掉就可以。同时需要修改一下js。
<script type="text/javascript"> function f(str){ var sub_menu = document.getElementById(str); var dis_v = sub_menu.style.display; if(dis_v == "none") sub_menu.style.display = "block"; else sub_menu.style.display = "none"; } </script>
仔细看,不然你就会发现你需要点击两次才会出现想要的效果。
(资源库 www.zyku.net)
您可能感兴趣的文章
- 06-26highlightjs网页代码高亮插件调用方法
- 05-10JS - 获取文件后缀,判断文件类型(比如是否为图片格式)
- 05-10js中!和!!的区别与用法
- 05-10js实现文章目录索引导航(table of content)
- 05-10JS实现单张或多张图片持续无缝滚动的示例代码
- 05-10js根据后缀判断文件文件类型的代码
- 05-10JS端基于download.js实现图片、视频时直接下载而不是
- 04-02CentOS安装Nodejs教程
- 02-11JS操作剪贴板代码详解
- 01-04帝国CMS页面JS调用登录状态loginjs.php中获取会员头像
- 10-19AirPods3配对iPhone设备教程分享
- 11-20三星Galaxy Buds2怎样连接手机
- 12-28丘比特Piano-丘比特Piano应用软件功能
- 03-14vivoy53s关闭图标自动补位教程
- 07-10发布一个帝国cms无缝隙滚动图片标签
- 01-23MySql数据库表类型MYISAM与InnoDB的区
- 01-12初级中药师中药学-初级中药师中药学应
- 01-11开心相册乐园-开心相册乐园应用软件功
- 02-09浅谈tensorflow语义分割api的使用(dee
- 09-17keep手环如何绑定手机
最近更新
阅读排行
猜你喜欢
- 01-11读书吧-读书吧应用软件功能介绍
- 03-18opporeno6pro开启来电闪光灯操作方法
- 01-11兔子视频编辑器-兔子视频编辑器应用软
- 12-27小天才兜兜龙-小天才兜兜龙应用软件功
- 12-28备孕小助手-备孕小助手应用软件功能介
- 01-24华为mate40pro充电提示音开启方法
- 05-05SQL Server 的 Enterprise、Standard
- 12-23HTML <center> 标签 - HTML5 不支持
- 09-17微信厦门核酸检测预约方法分享
- 01-17kiinii-kiinii应用软件功能介绍