本文原地址http://aeroyoung.github.io/2015/09/01/Fold/
这是我的Github博客,里面有大量源代码欢迎查看
还是在写长博客的时候想到的需求,在文章中点击<h1><h2>等标签的时候自动折叠该标题下的所有子标题和正文。我想到了利用jQuery来实现,给所有标题写加上一个类“art-title”,再在js文件中添加点击事件。然后用nextUntil遍历后续同胞元素,当遇到同级或更高级别的标题时候遍历停止,期间所有元素都被隐藏/显示。
jQuery代码
需要引入bootstrap和font-awsome
//点击文字h 折叠之后的文字
$(".art-title").click(function(){
//获得标签级别
var tagName=$(this).get(0).tagName;
tagName=tagName.toLowerCase();
var level=tagName.substr(1,1);
//遍历子元素
var brothers=$(this).nextUntil(tagName);
brothers.each(function(index, element) {
var brotagName=$(this).get(0).tagName;
if(brotagName.substr(0,1)=="H"){//alert(brotagName);
var brolevel=brotagName.substr(1,1);
if(brolevel>=level) {$(this).toggle(1000);}
else{return false;}//结束循环
}else{
$(this).toggle(1000);