zoukankan      html  css  js  c++  java
  • 博客园自定义界面样式(侧边栏、进度条、回到顶部、目录)

    最近这一段时间对我的博客园样式做了一些调整。总体样式改变了不少。在这里就分享下我的过程。

    一、博客园后台管理

    1、申请 JS 权限

    这是第一步,如果需要定制的样式就需要先申请 JS 权限。

    登录博客园后,管理=》设置,这这个面板里面有申请的按钮。

    申请后等待审核,审核通过后就可以设置了。

    2、侧边栏基本设置

    这一部分主要是对侧边栏选项卡、数据条数等的显示控制。

    在:管理=》选项,这个面板中设置(这里根据自己喜好设置)

    3、设置板块功能分析

    设置面板有几个地方可以写代码分别介绍下。

    1)、页面定制 CSS 代码

    这里可以对页面中的任何地方的样式进行设置,在设置前首相需要对页面的结构了解清楚

    2)、博客侧边栏公告

    这部分主要是针对侧边栏的公告设置的

    3)、页首 HTML 代码

    这里输入的代码会插入在页首,在 id 为 “page_begin_html” 的容器内

    4)、页脚 HTML 代码

    这里输入的代码会插入在页尾,在 id 为 “page_end_html” 的容器内

    二、侧边栏样式调整

    我对侧边栏做的调整有两处地方。

    1、公告栏添加头像

    在:选项=》博客侧边栏公告,这里对公告内容样式调整

    <div align="center" style="postion">
      <a href="https://www.cnblogs.com/zhurong/">
        <img style="position: absolute;right: 20px;top: 14px; 100px;height: 100px;border-radius: 50%;"
          src="//pic.cnblogs.com/avatar/592961/20180802101346.png">
      </a>
    </div>

    这个调整是在公告栏里面加入自己的头像,并可以点击到博客地址。

    效果:

    2、随笔分类换行

    我随笔分类名字都比较短,就想把这些两个两个一行,同时也对整个页面中内容布局大小做了调整。

    主要是在:选项=》 “页面定制 CSS 代码” 中输入以下代码:

    /*内容、右侧菜单样式*/
    #main {
      width: 1300px;
    }
    
    #mainContent {
      width: 940px;
    }
    
    #sideBar {
      width: 340px;
    }
    
    #blog-news {
      position: relative;
    }
    
    #sidebar_postcategory ul {
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
    }
    
    #sidebar_postcategory li {
      width: 139px;
    }
    
    #under_post_news,
    #under_post_kb {
      border: 0;
      padding: 0;
    }

    效果:

    三、回到顶部、进度条

    1、回到顶部

    这一部分代码主要是放在了:选项=》“页首 HTML 代码” 这里面,

    具体代码:

    <!-- 回到顶部 -->
    <style>
      #back-top {
        position: fixed;
        bottom: 5rem;
        right: 5rem;
        z-index: 10;
      }
    
      #back-top span {
        width: 50px;
        height: 64px;
        display: block;
        background: url(http://images.cnblogs.com/cnblogs_com/seanshao/855033/o_rocket.png) no-repeat center center;
      }
    
      #back-top a {
        outline: none
      }
    </style>
    <script type="text/javascript">
      $(function () {
        // 默认是隐藏“回到顶部”按钮
        $("#back-top").hide();
        // 滚动距离顶部 500 像素时 淡入、淡出
        $(window).scroll(function () {
          if ($(this).scrollTop() > 500) {
            $('#back-top').fadeIn();
          } else {
            $('#back-top').fadeOut();
          }
        });
        // 回到顶部,点击事件
        $('#back-top a').click(function () {
          $('body,html').animate({
            scrollTop: 0
          }, 800);
          return false;
        });
      });
    </script>
    <p id="back-top" style="display:none" title="回到页面顶部"><a href="#top"><span></span></a></p>

    这个样式是当距离顶部一定距离才显示这个按钮。

    2、进度条

    进度条我是放在了页面底部,所以代码放在了:选项=》“页脚 HTML 代码”,主要代码是:

    <!-- 进度条 -->
    <style>
      progress {
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        width: 100%;
        text-align: center;
        height: 0.5rem;
        border: 1px solid #999;
        border-radius: 1rem;
        z-index: 5;
        -webkit-apperance: none;
      }
    
      ::-webkit-progress-bar {
        background-color: #eee;
        border-radius: 1rem;
      }
    
      ::-webkit-progress-value {
        background-color: #169fe6ad;
        border-radius: 1rem;
      }
    </style>
    <script>
      // 生成元素并添加到文档尾部
      var progress = document.createElement('progress');
      progress.id = 'progress';
      document.body.appendChild(progress);
    
      // 计算当前页面的高度并赋值给进度条
      var H;
      window.onload = function () {
        progress.max = H = home.scrollHeight;
        progress.value = 0;
      }
    
      // 监听滚动,实时计算滚动条进度值
      window.onscroll = function () {
        var h = document.documentElement.scrollTop || document.body.scrollTop;
        progress.value = h;
        var radio = (h / H >= 1) ? 1 : h / H;
        progress.innerHTML = progress.title = Math.floor(100 * radio) + '%';
      }
    </script>

    进度条的位置、样式可以根据自己喜好进行设置。

    四、目录

    想使自己写的文章能够自动生成统一的目录样式、功能,需要设置两个地方:

    1、后台管理自动生成目录

    这里是把文章中的 h 标签提前处理,生成标签。

    功能:

    • 最多可生成3级标题
    • 文章中的标题必须是 h1、h2、h3 这三个的组合

    (这里是根据当前代码设定的,可以根据实际情况修改代码,以达到其他效果)

    具体的代码:

    <!-- 目录索引列表生成 -->
    <script>
      function GenerateContentList() {
        if ($('#cnblogs_post_body').length == 0) {
          return;
        }
        // 先取出三级标题标签
        var jquery_h1_list = $('#cnblogs_post_body h1');
        var jquery_h2_list = $('#cnblogs_post_body h2');
        var jquery_h3_list = $('#cnblogs_post_body h3');
    
        var content = '<div id="navCategory">';
        content += '<p style="font-size:18px"><b>目录</b></p>';
        content += '<ul id="left_menu" class="first_class_ul">';
    
        // 一级标题开始
        if (jquery_h1_list.length > 0) {
          for (var i = 0; i < jquery_h1_list.length; i++) {
            var li_content = '<li><a href="#_label' + i + '">' + $(jquery_h1_list[i]).text() + '</a></li>';
            var nextH1Index = i + 1;
            if (nextH1Index == jquery_h1_list.length) {
              nextH1Index = 0;
            }
            var jquery_h2_list = $(jquery_h1_list[i]).nextUntil(jquery_h1_list[nextH1Index], "h2");
            if (jquery_h2_list.length > 0) {
              li_content += '<ul class="second_class_ul">';
            }
            for (var j = 0; j < jquery_h2_list.length; j++) {
              li_content += '<li><a href="#_label2_' + i + '_' + j + '">' + $(jquery_h2_list[j]).text() + '</a></li>';
              var nextH2Index = j + 1;
              var next;
              if (nextH2Index == jquery_h2_list.length) {
                if (i + 1 == jquery_h1_list.length) {
                  next = jquery_h1_list[0];
                } else {
                  next = jquery_h1_list[i + 1];
                }
              } else {
                next = jquery_h2_list[nextH2Index];
              }
              var jquery_h3_list = $(jquery_h2_list[j]).nextUntil(next, "h3");
              if (jquery_h3_list.length > 0) {
                li_content += '<ul class="third_class_ul">';
              }
              for (var k = 0; k < jquery_h3_list.length; k++) {
                li_content += '<li><a href="#_label3_' + i + '_' + j + '_' + k + '">' + $(jquery_h3_list[k]).text() +
                  '</a></li>';
              }
              if (jquery_h3_list.length > 0) {
                li_content += '</ul>';
              }
              li_content += '</li>';
            }
            if (jquery_h2_list.length > 0) {
              li_content += '</ul>';
            }
            li_content += '</li>';
            content += li_content;
          }
          content += '</ul>';
          content += '</div>';
        } else if (jquery_h2_list.length > 0) {
          for (var i = 0; i < jquery_h2_list.length; i++) {
            var li_content = '<li><a href="#_label' + i + '">' + $(jquery_h2_list[i]).text() + '</a></li>';
            var nextH1Index = i + 1;
            if (nextH1Index == jquery_h2_list.length) {
              nextH1Index = 0;
            }
            var jquery_h3_list = $(jquery_h2_list[i]).nextUntil(jquery_h2_list[i + 1], "h3");
            if (jquery_h3_list.length > 0) {
              li_content += '<ul class="third_class_ul">';
            }
            for (var j = 0; j < jquery_h3_list.length; j++) {
              li_content += '<li><a href="#_label2_' + i + '_' + j + '">' + $(jquery_h3_list[j]).text() + '</a></li>';
            }
            if (jquery_h3_list.length > 0) {
              li_content += '</ul>';
            }
            li_content += '</li>';
            content += li_content;
          }
          content += '</ul>';
          content += '</div>';
        } else if (jquery_h3_list.length > 0) {
          for (var i = 0; i < jquery_h3_list.length; i++) {
            var li_content = '<li><a href="#_label' + i + '">' + $(jquery_h3_list[i]).text() + '</a></li>';
            content += li_content;
          }
          content += '</ul>';
          content += '</div>';
        } else {
          return;
        }
        $($('#cnblogs_post_body')[0]).prepend(content);
      }
      GenerateContentList();
    </script>

    这里只是生产了标题,还要设置其样式,样式放在了:选项=》“页面定制 CSS 代码”:

    /** 左侧目录 */
    #navCategory {
      position: fixed;
      z-index: 99;
      top: 325px;
      left: 20px;
      max-width: 300px;
    }
    
    #left_menu {
      text-align: left;
      border-left: 1px solid #ddd;
      font-size: 14px;
      margin-left: 20px !important;
    }
    
    #left_menu ul {
      margin: 0 0 10px 20px;
    }
    
    #left_menu li {
      list-style: none !important;
    }
    
    #left_menu a {
      display: inline-table;
      margin-left: 5px;
      white-space: nowrap;
      text-decoration: none;
      color: #313131;
      outline: 0;
      text-decoration: none !important;
    }
    
    #left_menu a:hover {
      color: #eb5055;
      border-bottom: none !important;
    }
    
    #left_menu>li::before {
      position: relative;
      top: 0;
      left: -4px;
      display: inline-block;
      width: 7px;
      height: 7px;
      content: "";
      border-radius: 50%;
      background-color: #eb5055;
    }

    2、文章中设置锚点

    上面只是生成了具体的目录,但是点击没有效果,这里就需要对文章中的 h 标签的 id 进行设置。

    注意:上面生成目录的代码中,在一级目录中里面包含了 <a> ,设置了其属性 src ,我这里选的是 "_label" 作为前缀,

    不同等级命名规则:

    • 一级:_label0(第一个一级标签),_label1(第二个一级标签)
    • 二级:_label2_0_0(二级标签,第一个一级标签下的第一个二级标签)
    • 三级:_label3_0_0_0(三级标签,第一个级标签下的第一个二级标签下的第一个三级标签)

    这里之所以用 0 是上面代码循环从 0 开始

  • 相关阅读:
    PL/SQL基础
    Oracle数据库安装与卸载
    数据结构与算法学习(四):树
    数据结构与算法学习(三):算法经典问题
    数据结构与算法学习(二):栈和队列
    数据结构与算法学习(一):线性表
    NodeJS+axios上传图片
    WCF可靠性会话之服务分流
    MVC的局部视图传参的小技巧--见人才网头部导航
    MVC分层处理
  • 原文地址:https://www.cnblogs.com/zhurong/p/12786887.html
Copyright © 2011-2022 走看看