jQuery实现文档树效果
发布时间 - 2026-01-10 23:11:07 点击率:次情形:本类别下面有好多子类别,每个子类别下面又有好多孙类别;需求:当点击本类别时,子类别如果是显示的就让它隐藏,子类别如果是隐藏的就让它显示。

效果如下:
图(1)点击前
图(2)点击后
代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<style>
*{
margin:0;
padding:0;
list-style: none;
}
.box{
width: 250px;
height: auto;
padding: 20px;
background: lightgrey;
margin:0 auto;
}
.box li{
line-height: 30px;
/*注意:height没有被设置,可以根据实际需要自动调整*/
position: relative;
}
.box li em{
position: absolute;
left:0;
top:7px;
width: 16px;
height: 16px;
background-image: url("http://www.qdfuns.com/misc.php?mod=attach&genre=editor&aid=123b5048273b92eb544ad6eb0ed57c44");
background-size:100%;
cursor: pointer;
}
.box li em.open{
background-image: url("http://www.qdfuns.com/misc.php?mod=attach&genre=editor&aid=8f89447399822b0294ae590ccc641bf5");
background-size:100%;
}
.box li span{
padding-left: 20px;
/*因为span前面的em已经绝对定位,脱离文档流了,所以span的左边界直达 li*/
}
.box ul{
display: none;
}
.two{
margin-left: 20px;
}
.three{
margin-left: 40px;
}
.four{
margin-left: 40px;
}
/*ul.box下的li显示,其中有折叠的li加em;
ul.box下的ul隐藏,其内部的li是没法显示的*/
</style>
</head>
<body>
<ul class="box">
<li><em></em><span>第一级第一个</span>
<ul class="two">
<li><span>第二级第一个</span></li>
<li><em></em><span>第二级第二个</span>
<ul class="three">
<li><em></em><span>第三级第一个</span>
<ul class="four">
<li><span>第四级第一个</span></li>
<li><span>第四级第二个</span></li>
</ul>
</li>
<li><span>第三级第二个</span></li>
</ul>
</li>
<li><em></em><span>第二级第三个</span>
<ul class="three">
<li><span>第三级第一个</span></li>
<li><span>第三级第二个</span></li>
</ul>
</li>
</ul>
</li>
<li><em></em><span>第一级第一个</span>
<ul class="two">
<li><span>第二级第一个</span></li>
<li><em></em><span>第二级第二个</span>
<ul class="three">
<li><em></em><span>第三级第一个</span>
<ul class="four">
<li><span>第四级第一个</span></li>
<li><span>第四级第二个</span></li>
</ul>
</li>
<li><span>第三级第二个</span></li>
</ul>
</li>
</ul>
</li>
</ul>
<script src="http://s0.kuaizhan.com/res/skin/js/lib/jquery-2.0.3.min.js"></script>
<script>
/*思路:
* 1.让前面有em的span加上小手效果;
* 2.点击span or em的时候,看他父容器下是否有ul,如果有,让其显示,否则,隐藏
* */
var $box=$('.box');
var $aSpan=$box.find('span');
//1.让前面有em的span加上小手效果;
$aSpan.each(function(index,item){
//if($(item).prev().length){ $(item).css('cursor','pointer');};思路1:
$(item).prev('em').next('span').css('cursor','pointer'); //思路2:
});
//2.点击span or em的时候,看他父容器下是否有ul,如果有,让其显示,否则,隐藏
$box.click(function(e){
//当点击的事件源是em or span的时候,我们看其父级下是否有ul
// 如果有:展开让其闭合,闭合就让其展开;
if(e.target.tagName.toLowerCase()=='em' || e.target.tagName.toLowerCase()=='span'){
var $parent=$(e.target).parent();
var $ul=$parent.children('ul');
if($ul){
if($ul.css('display')=='block'){//展开,让其闭合
//当闭合的时候,让当前容器下,所有的em都移除open,所有的ul都隐藏;
$parent.find('ul').hide();
$parent.find('em').removeClass('open');
}else{ //闭合让其展开
$ul.show();
$parent.children('em').addClass('open');
}
}
}
})
</script>
</body>
</html>
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# jquery
# 文档树
# jquery树形菜单
# 目录树
# jQuery仿写百度百科的目录树
# jquery实现的树形目录实例
# jQuery遍历节点树方法分析
# jQuery树形控件zTree使用小结
# 多功能jQuery树插件zTree实现权限列表简单实例
# jquery树形菜单效果的简单实例
# jQuery zTree加载树形菜单功能
# jquery实现树形菜单完整代码
# 轻松学习jQuery插件EasyUI EasyUI创建树形菜单
# jquery插件treegrid树状表格的使用方法详解(.Net平台)
# 第一个
# 第二个
# 让其
# 四级
# 看他
# 让它
# 又有
# 第三个
# 可以根据
# 流了
# 移除
# 看其
# 文档
# 其中有
# 有好多
# px
# width
# height
# auto
# background
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
网站优化排名时,需要考虑哪些问题呢?
网站制作大概多少钱一个,做一个平台网站大概多少钱?
如何在万网自助建站中设置域名及备案?
JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)
Laravel项目怎么部署到Linux_Laravel Nginx配置详解
佛山网站制作系统,佛山企业变更地址网上办理步骤?
Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】
如何为不同团队 ID 动态生成多个独立按钮
什么是JavaScript解构赋值_解构赋值有哪些实用技巧
iOS UIView常见属性方法小结
Laravel如何创建自定义中间件?(Middleware代码示例)
百度浏览器网页无法复制文字怎么办 百度浏览器复制修复
如何在建站之星网店版论坛获取技术支持?
JavaScript如何实现继承_有哪些常用方法
Laravel如何自定义错误页面(404, 500)?(代码示例)
JavaScript如何实现音频处理_Web Audio API如何工作?
JS中对数组元素进行增删改移的方法总结
详解阿里云nginx服务器多站点的配置
如何快速打造个性化非模板自助建站?
企业网站制作这些问题要关注
非常酷的网站设计制作软件,酷培ai教育官方网站?
JavaScript如何实现类型判断_typeof和instanceof有什么区别
Linux后台任务运行方法_nohup与&使用技巧【技巧】
Laravel如何实现用户角色和权限系统_Laravel角色权限管理机制
中山网站制作网页,中山新生登记系统登记流程?
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?
Laravel如何设置自定义的日志文件名_Laravel根据日期或用户ID生成动态日志【技巧】
如何确保FTP站点访问权限与数据传输安全?
Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置
浅析上传头像示例及其注意事项
LinuxShell函数封装方法_脚本复用设计思路【教程】
轻松掌握MySQL函数中的last_insert_id()
javascript基于原型链的继承及call和apply函数用法分析
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
Linux系统命令中tree命令详解
黑客如何通过漏洞一步步攻陷网站服务器?
Python数据仓库与ETL构建实战_Airflow调度流程详解
网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?
如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南
Gemini手机端怎么发图片_Gemini手机端发图方法【步骤】
Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理
Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转
laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法
手机网站制作与建设方案,手机网站如何建设?
如何快速生成橙子建站落地页链接?
详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点
Laravel怎么生成URL_Laravel路由命名与URL生成函数详解
如何快速生成专业多端适配建站电话?
谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程

