本实例实现了树形的动态菜单,兼容IE8,火狐,Chrome等浏览器。使用了jQuery的toggle() 方法。效果和代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>jquery的树形菜单代码 </title> <meta name="keywords" content="www.cnblogs.com/jihua"/> <style type="text/css"> body { font-family:"宋体"; font-size: 12px; line-height: 1.5em; color:#7FB0C8; padding:0; margin:0; background: #336699;} ul,ol,li,dl,dt,dd { margin:0; padding:0; list-style-type:none;} h1,h2,h3,form,input,iframe,span { margin:0; padding:0;} a { color:#7FB0C8;} a:link {color: #7FB0C8; TEXT-DECORATION: none;} a:visited {color: #7FB0C8; TEXT-DECORATION: none;} a:hover {color: #fff; TEXT-DECORATION: none;} .white { color:#fff;} .white a:link {color: #fff; TEXT-DECORATION: none;} .white a:visited {color: #fff; TEXT-DECORATION: none;} .white a:hover {color: #73E1F5; TEXT-DECORATION: none;} /* 树形菜单开始 */ .close { float:right; clear:right; font-size:12px; font-weight:normal; cursor:pointer; padding-right:10px;} .title { font-size:14px; color:#fff; margin-bottom:10px; padding-left:5px; width:290px;} .menu { width:290px; height:330px; margin-bottom:10px;} .l1 { background:#000; font-size:13px; padding:5px 0 0 30px; height:20px; margin-bottom:5px; cursor:pointer;} .slist { margin:0 0 5px 0; display:none;} .l2 { padding:0 0 0 35px; font-size:13px;} .l2 a { padding:6px 0 0 5px; width:230px; height:21px; display:block;} .currentl2 a,.l2 a:hover { background:#1E5A82; color:#fff;} .sslist { background:#156890; width:235px; overflow:hidden; margin:0 0 5px 35px; display:none;} .l3 a { padding:6px 0 0 5px; width:230px; height:20px; display:block;} .currentl3 a,.l3 a:hover { color:#fff; font-weight:bold;} </style> <script type="text/javascript" src="http://keleyi.com/keleyi/pmedia/jquery/jquery-1.4.2.min.js"></script> <script type="text/javascript"> // 树状菜单 $(document).ready(function () { $(".l1").toggle(function () { $(".slist").animate({ height: 'toggle', opacity: 'hide' }, "slow"); $(this).next(".slist").animate({ height: 'toggle', opacity: 'toggle' }, "slow"); }, function () { $(".slist").animate({ height: 'toggle', opacity: 'hide' }, "slow"); $(this).next(".slist").animate({ height: 'toggle', opacity: 'toggle' }, "slow"); }); $(".l2").toggle(function () { $(this).next(".sslist").animate({ height: 'toggle', opacity: 'toggle' }, "slow"); }, function () { $(this).next(".sslist").animate({ height: 'toggle', opacity: 'toggle' }, "slow"); }); $(".l2").click(function () { $(".l3").removeClass("currentl3"); $(".l2").removeClass("currentl2"); $(this).addClass("currentl2"); }); $(".l3").click(function () { $(".l3").removeClass("currentl3"); $(this).addClass("currentl3"); }); $(".close").toggle(function () { $(".slist").animate({ height: 'toggle', opacity: 'show' }, "fast"); $(".sslist").animate({ height: 'toggle', opacity: 'show' }, "fast"); }, function () { $(".slist").animate({ height: 'toggle', opacity: 'hide' }, "fast"); $(".sslist").animate({ height: 'toggle', opacity: 'hide' }, "fast"); }); }); </script> </head> <body> <h1 id="span-class-close-全部收起-展开-span-Jihua树形菜单"><span class="close">全部收起/展开</span>Jihua树形菜单</h1> <div class="menu"> <h1 id="一级菜单">一级菜单</h1> <div class="slist"> <h2 id="a-href-二级菜单-a"><a href="#">二级菜单</a></h2> <ul class="sslist"> <li class="l3"><a href="#">·三级菜单</a></li> <li class="l3"><a href="#">·三级菜单</a></li> <li class="l3"><a href="#" target="_blank">·jihua.cnblogs.com</a></li> <li class="l3"><a href="#">·三级菜单</a></li> </ul> <h2 id="a-href-二级菜单-a"><a href="#">二级菜单</a></h2> <ul class="sslist"> <li class="l3"><a href="#">·三级菜单</a></li> <li class="l3"><a href="#">·三级菜单</a></li> <li class="l3"><a href="#" target="_blank">·三级菜单</a></li> <li class="l3"><a href="#">·三级菜单</a></li> </ul> <h2 id="a-href-二级jb-net-a"><a href="#">二级jb51.net</a></h2> </div> <h1 id="一级脚本">一级脚本</h1> <div class="slist"> <h2 id="a-href-二级菜单计划-a"><a href="#">二级菜单计划</a></h2> <h2 id="a-href-二级菜单-a"><a href="#">二级菜单</a></h2> <h2 id="a-href-二级菜单-a"><a href="#">二级菜单</a></h2> </div> <h1 id="一级菜单">一级菜单</h1> <div class="slist"> <h2 id="a-href-二级菜单-a"><a href="#">二级菜单</a></h2> <h2 id="a-href-二级菜单-a"><a href="#">二级菜单</a></h2> <h2 id="a-href-二级菜单-a"><a href="#">二级菜单</a></h2> </div> </div> </body> </html>
本实例用到jquery的toggle() 方法,介绍如下:
定义和用法
toggle() 方法切换元素的可见状态。
如果被选元素可见,则隐藏这些元素,如果被选元素隐藏,则显示这些元素。
语法
$(selector).toggle(speed,callback,switch)
提示和注释
注释:该效果适用于通过 jQuery 隐藏的元素,或在 CSS 中声明 display:none 的元素(但不适用于 visibility:hidden 的元素)。
以上就是jquery实现树形菜单完整代码,希望对大家的学习jquery程序设计有所帮助。

实现方法:1、用“$("img").delay(毫秒数).fadeOut()”语句,delay()设置延迟秒数;2、用“setTimeout(function(){ $("img").hide(); },毫秒值);”语句,通过定时器来延迟。

区别:1、axios是一个异步请求框架,用于封装底层的XMLHttpRequest,而jquery是一个JavaScript库,只是顺便封装了dom操作;2、axios是基于承诺对象的,可以用承诺对象中的方法,而jquery不基于承诺对象。

修改方法:1、用css()设置新样式,语法“$(元素).css("min-height","新值")”;2、用attr(),通过设置style属性来添加新样式,语法“$(元素).attr("style","min-height:新值")”。

增加元素的方法:1、用append(),语法“$("body").append(新元素)”,可向body内部的末尾处增加元素;2、用prepend(),语法“$("body").prepend(新元素)”,可向body内部的开始处增加元素。

删除方法:1、用empty(),语法“$("div").empty();”,可删除所有子节点和内容;2、用children()和remove(),语法“$("div").children().remove();”,只删除子元素,不删除内容。

在jquery中,apply()方法用于改变this指向,使用另一个对象替换当前对象,是应用某一对象的一个方法,语法为“apply(thisobj,[argarray])”;参数argarray表示的是以数组的形式进行传递。

去掉方法:1、用“$(selector).removeAttr("readonly")”语句删除readonly属性;2、用“$(selector).attr("readonly",false)”将readonly属性的值设置为false。

on()方法有4个参数:1、第一个参数不可省略,规定要从被选元素添加的一个或多个事件或命名空间;2、第二个参数可省略,规定元素的事件处理程序;3、第三个参数可省略,规定传递到函数的额外数据;4、第四个参数可省略,规定当事件发生时运行的函数。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

Dreamweaver Mac版
视觉化网页开发工具

SublimeText3汉化版
中文版,非常好用

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中