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

效果如下:
图(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
相关文章:
浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?
Java解压缩zip - 解压缩多个文件或文件夹实例
香港服务器租用每月最低只需15元?
山东云建站价格为何差异显著?
如何选择域名并搭建高效网站?
建站之星多图banner生成与模板自定义指南
,有什么在线背英语单词效率比较高的网站?
如何选择高效稳定的ISP建站解决方案?
活动邀请函制作网站有哪些,活动邀请函文案?
佛山企业网站制作公司有哪些,沟通100网上服务官网?
婚礼视频制作网站,学习*后期制作的网站有哪些?
php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】
如何挑选优质建站一级代理提升网站排名?
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
C++如何将C风格字符串(char*)转换为std::string?(代码示例)
建站之星如何防范黑客攻击与数据泄露?
建站主机服务器选购指南:轻量应用与VPS配置解析
如何通过商城自助建站源码实现零基础高效建站?
云南网站制作公司有哪些,云南最好的招聘网站是哪个?
制作表格网站有哪些,线上表格怎么弄?
如何通过VPS搭建网站快速盈利?
沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?
建站之星北京办公室:智能建站系统与小程序生成方案解析
自助网站制作软件,个人如何自助建网站?
如何通过山东自助建站平台快速注册域名?
安云自助建站系统如何快速提升SEO排名?
大学网站设计制作软件有哪些,如何将网站制作成自己app?
定制建站如何定义?其核心优势是什么?
测试制作网站有哪些,测试性取向的权威测试或者网站?
,柠檬视频怎样兑换vip?
电商平台网站制作流程,电商网站如何制作?
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
如何自定义建站之星网站的导航菜单样式?
如何在云指建站中生成FTP站点?
如何用PHP工具快速搭建高效网站?
如何快速搭建二级域名独立网站?
javascript基本数据类型及类型检测常用方法小结
宁波自助建站系统如何快速打造专业企业网站?
建站之星代理如何获取技术支持?
制作门户网站的参考文献在哪,小说网站怎么建立?
微信网站制作公司有哪些,民生银行办理公司开户怎么在微信网页上查询进度?
如何选择高效可靠的多用户建站源码资源?
洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?
交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?
网站制作培训多少钱一个月,网站优化seo培训课程有哪些?
整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?
制作网站的过程怎么写,用凡科建站如何制作自己的网站?
html制作网站的步骤有哪些,iapp如何添加网页?
如何批量查询域名的建站时间记录?
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
*请认真填写需求信息,我们会在24小时内与您取得联系。