情形:本类别下面有好多子类别,每个子类别下面又有好多孙类别;需求:当点击本类别时,子类别如果是显示的就让它隐藏,子类别如果是隐藏的就让它显示。

效果如下:
图(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
相关文章:
如何用腾讯建站主机快速创建免费网站?
香港服务器如何优化才能显著提升网站加载速度?
深圳网站制作费用多少钱,读秀,深圳文献港这样的网站很多只提供网上试读,但有些人只要提供试读的文章就能全篇下载,这个是怎么弄的?
建站之星安装步骤有哪些常见问题?
建站org新手必看:2024最新搭建流程与模板选择技巧
如何通过西部数码建站助手快速创建专业网站?
建站之星logo尺寸如何设置最合适?
如何在阿里云域名上完成建站全流程?
c# 服务器GC和工作站GC的区别和设置
C#如何使用XPathNavigator高效查询XML
如何通过WDCP绑定主域名及创建子域名站点?
Swift中swift中的switch 语句
如何打造高效商业网站?建站目的决定转化率
C#如何在一个XML文件中查找并替换文本内容
网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?
如何用西部建站助手快速创建专业网站?
高端建站三要素:定制模板、企业官网与响应式设计优化
海南网站制作公司有哪些,海口网是哪家的?
制作网站的基本流程,设计网站的软件是什么?
建站之星2.7模板:企业网站建设与h5定制设计专题
专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?
企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?
建站上市公司网站建设方案与SEO优化服务定制指南
建站之星后台搭建步骤解析:模板选择与产品管理实操指南
香港服务器租用费用高吗?如何避免常见误区?
建站之星后台密码遗忘或太弱?如何重置与强化?
网站制作软件免费下载安装,有哪些免费下载的软件网站?
临沂网站制作公司有哪些,临沂第四中学官网?
建站主机选虚拟主机还是云服务器更好?
如何确保西部建站助手FTP传输的安全性?
如何在Golang中指定模块版本_使用go.mod控制版本号
学校免费自助建站系统:智能生成+拖拽设计+多端适配
太平洋网站制作公司,网络用语太平洋是什么意思?
上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?
如何获取开源自助建站系统免费下载链接?
广州顶尖建站服务:企业官网建设与SEO优化一体化方案
宿州网站制作公司兴策,安徽省低保查询网站?
攀枝花网站建设,攀枝花营业执照网上怎么年审?
c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
C++如何编写函数模板?(泛型编程入门)
高性价比服务器租赁——企业级配置与24小时运维服务
建站之星如何助力网站排名飙升?揭秘高效技巧
专业网站建设制作报价,网页设计制作要考什么证?
如何快速查询域名建站关键信息?
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
建设网站制作价格,怎样建立自己的公司网站?
C#如何序列化对象为XML XmlSerializer用法
网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?
定制建站哪家更专业可靠?推荐榜单揭晓
*请认真填写需求信息,我们会在24小时内与您取得联系。