JavaScript点击标题折叠文章内容

论坛 期权论坛 脚本     
匿名技术用户   2021-1-5 11:34   21   0

本文原地址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); 
    }
  });
  if($(this).children("i").length>0) {
   $(this).children("i").remove();
  }else{ 
   $(this).prepend("<i class='fa fa-angle-double-down' style='font-style:normal'>  </i>");
  }
 });

同时要求在HTML文件中,标题下的内容(正文+子标题)都用一对<p></p>给包括起来,还得给所有标题写加上一个类“art-title”


分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:7942463
帖子:1588486
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP