hexo干货系列:(八)hexo文章自动隐藏侧边栏

前言


使用Jacman主题的时候发现打开具体文章后,侧边栏还是会展示,我想要的效果是自动隐藏侧边栏,并且展示目录。但是当我修改了主题配置文件里面close_aside属性为true的时候,发现侧边栏隐藏了,但是目录没出来。于是就有了这篇文章,让我带你一步步明白原理并解决问题~

正文


侧边栏的代码结构


如图:

  1. 为显示侧边栏按钮,对应的是openaside,默认隐藏
  2. 为文章目录,对应的是to和toc-aside,默认隐藏
  3. 为侧边栏,对应的是asidepart,默认是展示

实现自动隐藏侧边栏


那我们现在要做得就是打算一打开具体文章,默认先显示成文字目录,而不是侧边栏
要实现这个就要通过js来改变,我查找了对应的文件,发现在 \themes\jacman\layout\_partial\after_footer.ejs这里有相关代码:

  var m = $('#main'),
      a = $('#asidepart'), //侧边栏
      c = $('.closeaside'),//隐藏侧边栏
      o = $('.openaside'); //显示侧边栏
  c.click(function(){
    a.addClass('fadeOut').css('display', 'none');
    o.css('display', 'block').addClass('fadeIn');
    m.addClass('moveMain');
  });  
  //*******************************
   中间还有一些代码。。这里不展示
   //******************************
  <% if (is_post() && theme.close_aside) { %>
        getSize();
        if (myWidth >= 1024) {
          c.click();
        }
  <% } %>

上面代码可以看出来 is_post()用来判断当前是否post布局,大家记住我们博文详情页默认是post布局,所以为true. theme.close_aside这个是在主题配置文件_config.yml下面对应的配置:

close_aside: true  #close sidebar in post page if true
mathjax: false      #enable mathjax if true

我这边close_aside就设置了true,在post布局里面默认关闭侧边栏 如果页面宽度大于1024就触发c.click(),也就是触发了隐藏侧边栏的方法。 原本的代码c.click(function(){})里面只是简单的隐藏和显示了图标,最关键的目录对应的<div id="toc" class="toc-aside">没有显示,因为默认隐藏的。 没错,这就是问题的关键所在,所以我这里添加上了显示这个div的代码,正确代码如下:

  var m = $('#main'),
      a = $('#asidepart'), //侧边栏
      c = $('.closeaside'),//隐藏侧边栏
      o = $('.openaside'); //显示侧边栏
  c.click(function(){
    a.addClass('fadeOut').css('display', 'none');
    o.css('display', 'block').addClass('fadeIn');
     var m = $('#main'),
      a = $('#asidepart'), //侧边栏
      c = $('.closeaside'),//隐藏侧边栏
      o = $('.openaside'); //显示侧边栏
  c.click(function(){
    a.addClass('fadeOut').css('display', 'none');
    o.css('display', 'block').addClass('fadeIn');
    $('#toc.toc-aside').css('display', 'block').addClass('fadeIn'); //这个是我新加的,修改点
    m.addClass('moveMain');
  });  
  //*******************************
   中间还有一些代码。。这里不展示
   //******************************
  <% if (is_post() && theme.close_aside) { %>
        getSize();
        if (myWidth >= 1024) {
          c.click();
        }
  <% } %>

好了搞定,默认打开文章的效果如下:

总结


如果你没看懂的话也没关系,概括起来就修改两个地方

  1. \themes\jacman\_config.yml里面修改close_aside属性为true
close_aside: true  #close sidebar in post page if true
  1. \themes\jacman\layout\_partial\after_footer.ejs里面添加下面的代码,具体添加在哪里,看看文章里面有提到
 $('#toc.toc-aside').css('display', 'block').addClass('fadeIn'); //这个是我新加的,修改点

最后,厚颜无耻的求打赏..如果您认为博主的教程帮助到了你~ 你懂的o(^▽^)o (/▽\=)  

转载于:https://my.oschina.net/u/1424566/blog/645863

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值