当前位置:   article > 正文

个人博客美化_i'm jiecsdn

i'm jiecsdn

总体参考:

注:博客所有美化大部分(全部)都参考于以上教程,本文内容基于自身略有改动(照抄)

Butterfly 主题安装

参考链接:http://haiyong.site/post/22e1d5da.html

在 MyBlog 文件下打开命令行,运行命令,使用 Github 方式安装。升级方法:在主题目录下,进行 git pull

git clone -b master https://github.com/jerryc127/hexo-theme-butterfly.git themes/butterfly
  • 1

修改 Hexo 根目录下的 _config.yml,把主题改为 butterfly:

theme: butterfly
  • 1

安装 pug 以及 stylus 的渲染器

npm install hexo-renderer-pug hexo-renderer-stylus --save
  • 1

升级建议

  • 在 MyBlog 文件下新建一个文件 _config.butterfly.yml,并把 MyBlog\themes\butterfly目录的 _config.yml 内容复制到 _config.butterfly.yml 去,以后只需要在 _config.butterfly.yml 进行配置就行。
  • Hexo 会自动合并主题中的 _config.yml 和 _config.butterfly.yml 里的配置,如果存在同名配置,会使用 _config.butterfly.yml 的配置,其优先度较高。

修改博主头像

为了防止后续主题更新时,会将主题目录的文件覆盖,建议在 MyBlog/source 目录下存储个人文件,Hexo 会从 source 目录下识别。

博主头像存放的两种方式如下(任选其一即可):

  • 在 MyBlog/source 目录下本地存储头像
  • 头像上传到图床,通过 Url 访问
# Avatar (头像)
avatar:
  img: /img/avatar.png # 本地路径 或 图床 URL
  effect: false #自动旋转
  • 1
  • 2
  • 3
  • 4

生成文章唯一链接

参考链接:https://github.com/rozbo/hexo-abbrlink

1、安装插件,在 MyBlog 目录下打开 git 命令行,运行以下指令:

npm install hexo-abbrlink --save
  • 1

2、插件安装成功后,在 MyBlog 目录的配置文件 _config.yml 找到 permalink:

- permalink: :year/:month/:day/:title/
#修改为
+ permalink: posts/:abbrlink.html # posts为自定义前缀
+ abbrlink:
+   alg: crc32   #算法: crc16(default) and crc32
+   rep: hex     #进制: dec(default) and hex
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

在这里插入图片描述

本地搜索

参考链接:https://github.com/wzpan/hexo-generator-search

  1. 在 MyBlog 目录下打开 git 命令行,运行以下指令:

    npm install hexo-generator-search --save
    
    • 1
  2. 在 MyBlog 目录的 _config.yml 中最后添加

    search:
      path: search.xml
      field: all
      content: true
    
    • 1
    • 2
    • 3
    • 4
  3. 将 MyBlog 目录的 _config.butterfly.yml 中的 local_search 的 enable 项改为 true

    在这里插入图片描述

  4. 执行 hexo cl && hexo g && hxo s 命令,使用搜索功能

    在这里插入图片描述

Sitemap

在 MyBlog 目录下打开 git 命令行,运行以下指令:

npm install hexo-generator-sitemap --save
npm install hexo-generator-baidu-sitemap --save-dev
  • 1
  • 2

在 MyBlog 目录的 _config.yml 中最后添加

# https://github.com/hexojs/hexo-generator-sitemap
sitemap:
  path: sitemap.xml
  rel: false
  tags: true
  categories: true

# https://github.com/coneycode/hexo-generator-baidu-sitemap
baidusitemap:
    path: baidusitemap.xml
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

RSS

在 MyBlog 目录下打开 git 命令行,运行以下指令:

npm install hexo-generator-feed --save
  • 1

在 MyBlog 目录的 _config.yml 中最后添加

# https://github.com/hexojs/hexo-generator-feed
#Feed Atom
feed:
    type: atom
    path: atom.xml
    limit: 20
rss: /atom.xml

# Extensions
plugins:
    - hexo-generator-feed
    - hexo-generator-baidu-sitemap
    - hexo-generator-sitemap
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

追番插件

在 MyBlog 目录下打开 git 命令行,运行以下指令:

npm install hexo-bilibili-bangumi --save
  • 1

在 MyBlog 目录的 _config.yml 中最后添加

# 追番插件
# https://github.com/HCLonely/hexo-bilibili-bangumi
bangumi: # 追番设置
  enable: true
  path:
  vmid: # uid
  title: '追番列表'
  quote: '生命不息,追番不止!'
  show: 1
  lazyload: false #关闭懒加载,开启 _config.butterfly.yml 中的懒加载
  loading:
  metaColor:
  color:
  webp:
  progress:
  extra_options:
    key: value
cinema: # 追剧设置
  enable: true
  path:
  vmid: # uid
  title: '追剧列表' 
  quote: '生命不息,追剧不止!'
  show: 1
  lazyload: false #关闭懒加载,开启 _config.butterfly.yml  中的懒加载
  loading:
  metaColor:
  color:
  webp:
  progress:
  extra_options:
    key: value
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32

在 _config.butterfly.yml 中添加导航菜单

menu:
  首页: / || fas fa-home
  追番: /bangumis/index.html || fas fa-home
  • 1
  • 2
  • 3

夜间模式繁星(宇宙)背景

参考地址:https://blog.leonus.cn/2022/universe.html

  1. MyBlog/source/js 目录下创建 universe.js 文件,然后粘贴如下代码:

    function dark() {
        window.requestAnimationFrame = window.requestAnimationFrame || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame || window.msRequestAnimationFrame;
        var n, e, i, h, t = .05,
            s = document.getElementById("universe"),
            o = !0,
            a = "180,184,240",
            r = "226,225,142",
            d = "226,225,224",
            c = [];
    
        function f() {
            n = window.innerWidth, e = window.innerHeight, i = .216 * n, s.setAttribute("width", n), s.setAttribute("height", e)
        }
        function u() {
            h.clearRect(0, 0, n, e);
            for (var t = c.length, i = 0; i < t; i++) {
                var s = c[i];
                s.move(), s.fadeIn(), s.fadeOut(), s.draw()
            }
        }
        function y() {
            this.reset = function() {
                this.giant = m(3), this.comet = !this.giant && !o && m(10), this.x = l(0, n - 10), this.y = l(0, e), this.r = l(1.1, 2.6), this.dx = l(t, 6 * t) + (this.comet + 1 - 1) * t * l(50, 120) + 2 * t, this.dy = -l(t, 6 * t) - (this.comet + 1 - 1) * t * l(50, 120), this.fadingOut = null, this.fadingIn = !0, this.opacity = 0, this.opacityTresh = l(.2, 1 - .4 * (this.comet + 1 - 1)), this.do = l(5e-4, .002) + .001 * (this.comet + 1 - 1)
            }, this.fadeIn = function() {
                this.fadingIn && (this.fadingIn = !(this.opacity > this.opacityTresh), this.opacity += this.do)
            }, this.fadeOut = function() {
                this.fadingOut && (this.fadingOut = !(this.opacity < 0), this.opacity -= this.do /2,(this.x>n||this.y<0)&&(this.fadingOut=!1,this.reset()))},this.draw=function(){if(h.beginPath(),this.giant)h.fillStyle="rgba("+a+","+this.opacity+")",h.arc(this.x,this.y,2,0,2*Math.PI,!1);else if(this.comet){h.fillStyle="rgba("+d+","+this.opacity+")",h.arc(this.x,this.y,1.5,0,2*Math.PI,!1);for(var t=0;t<30;t++)h.fillStyle="rgba("+d+","+(this.opacity-this.opacity/20 * t) + ")", h.rect(this.x - this.dx / 4 * t, this.y - this.dy / 4 * t - 2, 2, 2), h.fill()
            } else h.fillStyle = "rgba(" + r + "," + this.opacity + ")", h.rect(this.x, this.y, this.r, this.r);
                h.closePath(), h.fill()
            }, this.move = function() {
                this.x += this.dx, this.y += this.dy, !1 === this.fadingOut && this.reset(), (this.x > n - n / 4 || this.y < 0) && (this.fadingOut = !0)
            }, setTimeout(function() {
                o = !1
            }, 50)
        }
        function m(t) {
            return Math.floor(1e3 * Math.random()) + 1 < 10 * t
        }
        function l(t, i) {
            return Math.random() * (i - t) + t
        }
        f(), window.addEventListener("resize", f, !1), function() {
            h = s.getContext("2d");
            for (var t = 0; t < i; t++) c[t] = new y, c[t].reset();
            u()
        }(), function t() {
            document.getElementsByTagName('html')[0].getAttribute('data-theme') == 'dark' && u(), window.requestAnimationFrame(t)
        }()
    };
    dark()
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
  2. MyBlog/source/css 目录下创建自定义 CSS 文件,例如 custom.css,用于存放自修改的 css 样式,然后粘贴如下代码:

    #universe {
        display: block;
        position: fixed;
        margin: 0;
        padding: 0;
        border: 0;
        outline: 0;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        pointer-events: none;
        z-index: 1;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
  3. 如果你的 css 没有引入,则需要打开主题的配置文件 _config.butterfly.yml,找到 injecthead,输入以下代码(注意缩进):

    - <link rel="stylesheet" href="/css/style.css">
    
    • 1

    在这里插入图片描述

    然后找到 injectbottom,输入以下代码:

    # 夜间模式背景
    - <canvas id="universe"></canvas> # 创建画布
    - <script src="/js/universe.js"></script> # 引入js
    
    • 1
    • 2
    • 3

    在这里插入图片描述

添加页脚徽标和计时器

在 MyBlog 目录下打开 git 命令行,运行以下指令:

npm install hexo-butterfly-footer-beautify --save
  • 1

在 MyBlog 目录的 _config.yml 中最后添加

# footer_beautify
# 页脚计时器:[Native JS Timer](https://akilar.top/posts/b941af/)
# 页脚徽标:[Add Github Badge](https://akilar.top/posts/e87ad7f8/)
footer_beautify:
  enable:
    timer: true # 计时器开关
    bdage: true # 徽标开关
  priority: 5 #过滤器优先权
  enable_page: all # 应用页面
  exclude:
    # - /posts/
    # - /about/
  layout: # 挂载容器类型
    type: id
    name: footer-wrap
    index: 0
  # 计时器部分配置项
  runtime_js: /js/runtime.min.js
  runtime_css: /css/runtime.min.css
  # 徽标部分配置项
  swiperpara: 0 #若非0,则开启轮播功能,每行徽标个数
  bdageitem:
    - link: https://hexo.io/ #徽标指向网站链接
      shields: https://img.shields.io/badge/Frame-Hexo-blue?style=flat&logo=hexo #徽标API
      message: 博客框架为Hexo_v5.4.0 #徽标提示语
    - link: https://butterfly.js.org/
      shields: https://img.shields.io/badge/Theme-Butterfly-6513df?style=flat&logo=bitdefender
      message: 主题版本Butterfly_v4.2.2
    - link: https://www.jsdelivr.com/
      shields: https://img.shields.io/badge/CDN-jsDelivr-orange?style=flat&logo=jsDelivr
      message: 本站使用JsDelivr为静态资源提供CDN加速
    - link: https://beian.miit.gov.cn/#/Integrated/index
      shields: https://img.shields.io/badge/冀ICP备-2021000496号-e1d492?style=flat&logo=
      message: 本站已在湘进行备案
    - link: https://github.com/
      shields: https://img.shields.io/badge/Source-Github-d021d6?style=flat&logo=GitHub
      message: 本站项目由Github托管
    - link: http://creativecommons.org/licenses/by-nc-sa/4.0/
      shields: https://img.shields.io/badge/Copyright-BY--NC--SA%204.0-d42328?style=flat&logo=Claris
      message: 本站采用知识共享署名-非商业性使用-相同方式共享4.0国际许可协议进行许可
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40

新建 MyBlog\source\js\runtime.min.js

var now=new Date;function createtime(){var t=new Date("2/01/2023 00:00:00");now.setTime(now.getTime()+250);var e=(now-t)/1e3/60/60/24,a=Math.floor(e),n=(now-t)/1e3/60/60-24*a,r=Math.floor(n);1==String(r).length&&(r="0"+r);var s=(now-t)/1e3/60-1440*a-60*r,i=Math.floor(s);1==String(i).length&&(i="0"+i);var o=(now-t)/1e3-86400*a-3600*r-60*i,l=Math.round(o);1==String(l).length&&(l="0"+l);let g="";g=r<18&&r>=9?`<img class='boardsign' src='/img/badge1.svg' title='大丈夫只患功名不立,何患无妻?'><span class='textTip'> <br> 本站居然运行了 ${a} 天</span><span id='runtime'> ${r} 小时 ${i}${l} 秒 </span> <i class='fas fa-heartbeat' style='color:red'></i>`:`<img class='boardsign' src='/img/badge2.svg' title='得即高歌失即休,多愁多恨亦悠悠。今朝有酒今朝醉,明日愁来明日愁。'><span class='textTip'> <br> 本站居然运行了 ${a} 天</span><span id='runtime'> ${r} 小时 ${i}${l} 秒 </span> <i class='fas fa-heartbeat' style='color:red'></i>`,document.getElementById("workboard")&&(document.getElementById("workboard").innerHTML=g)}setInterval((()=>{createtime()}),250);
  • 1

新建 MyBlog\source\css\runtime.min.css

div#runtime{width:180px;margin:auto;color:#fff;padding-inline:5px;border-radius:10px;background-color:rgba(0,0,0,.7)}#workboard{font-size:12px}[data-theme=dark] div#runtime{color:#28b4c8;box-shadow:0 0 5px rgba(28,69,218,.71);animation:flashlight 1s linear infinite alternate}#ghbdages .github-badge img{height:20px}@-moz-keyframes flashlight{from{box-shadow:0 0 5px #1478d2}to{box-shadow:0 0 2px #1478d2}}@-webkit-keyframes flashlight{from{box-shadow:0 0 5px #1478d2}to{box-shadow:0 0 2px #1478d2}}@-o-keyframes flashlight{from{box-shadow:0 0 5px #1478d2}to{box-shadow:0 0 2px #1478d2}}@keyframes flashlight{from{box-shadow:0 0 5px #1478d2}to{box-shadow:0 0 2px #1478d2}}
  • 1

关于页面

参考链接:https://anzhiy.cn/posts/e62b.html

实际效果:

  1. 添加 about 页面,在 MyBlog 目录下打开 git 命令行,运行以下指令:

    hexo hew page "about"
    
    • 1

    打开 MyBlog/source/about/index.md 修改页面配置

    title: 关于
    date: 2023-02-02 14:58:35
    aside: false
    top_img: false
    background: "#f8f9fe"
    comments: false
    type: "about"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
  2. 新建 themes/butterfly/layout/includes/page/about.pug

    #about-page
      .author-box
        .author-img
          img.no-lightbox(src='https://img02.anzhiy.cn/adminuploads/1/2022/09/15/63232b7d91d22.jpg')
        .image-dot
      p.p.center.logo.large 关于我
      p.p.center.small 生活明朗,万物可爱✨
      .author-content
        .author-content-item.myInfoAndSayHello
          .title1 你好,很高兴认识你
    声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/article/detail/48947
推荐阅读
相关标签