<span style="color:#777777">title: Hexo 搭配 GitHub 建立博客, 选用 nexT 主题
date: 2021-04-26 19:21:20
categories:- [兴趣, 网站, 博客]
tags:- Hexo- Git
password:
top: 100
typora-root-url: ..
</span>

整理网上的Next优化方法,外加写一份文章

感觉博客还行,不再羡慕别人的主题了

特效全开,跟开了吃鸡一样,电脑呼呼的

看了下建站时间,花了23天整,为了一个工具,感觉血亏

我的博客 机械细胞 (jxxb.top)

Hexo 博客搭建

Hexo是一款基于Node.js的静态博客框架,依赖少易于安装使用,可以方便的生成静态网页托管在GitHub上.

因为Hexo的创建者是台湾人,对中文的支持很友好,可以选择中文进行查看。

官网: hexo官网

<!-- more -->

安装 Git

pass

参考:

  1. Git - Book (git-scm.com)

  2. 超详细Git 安装教程(Windows)eno_yang的博客-CSDN博客git安装

Git 代码备份

主要是一些为源文件备份的代码,用于git push

npm install -g hexo-cli
hexo init MyBlog
cd MyBlog
npm install
hexo generate
hexo server
.
git config --global user.name "yourname"
git config --global user.email "youremail"
git config user.name
git config user.email
ssh-keygen -t rsa -C "youremail"
ssh -T git@github.com
.
deploy:type: gitrepo: <repository url> #https://bitbucket.org/JohnSmith/johnsmith.bitbucket.iobranch: [branch]message: [message]
npm install hexo-deployer-git --save
hexo clean
hexo generate
hexo deploy
.
git branch newbranch
git branch
git checkout newbranch
git add .
git commit -a
git status
git checkout source
git merge newbranch
git diff
git push -u origin source
git branch -D newbranch
.
git init
git add .
git commit -m "20210423手动push"
git branch -M source
git remote add origin https://github.com/Liuzh25/Liuzh25.github.io.git
git push -u origin source
git push origin source --force
.
git branch -a
git push origin --delete new

安装nodejs

pass

参考:

  1. Node.js 中文网

安装hexo

选择准备安装的目录,打开git bash,输入

<span style="color:#333333">//全局安装
<span style="color:#3300aa">npm</span> install <span style="color:#0000cc">-g</span> hexo-cli
//查看一下版本
hexo <span style="color:#0000cc">-v</span>
​
//初始化hexo, 即创建<span style="color:#aa1111">"myblog"</span>文件夹并添加相关文件
hexo init myblog//创建文件夹
<span style="color:#3300aa">cd</span> myblog //进入这个myblog文件夹
<span style="color:#3300aa">npm</span> install//添加相关文件
hexo g//生成文件
hexo s//本地浏览</span>

打开hexo的服务,在浏览器输入localhost:4000就可以看到你生成的博客了。

GitHub创建个人仓库

创建一个和你用户名相同的仓库,后面加.github.io,只有这样,将来要部署到GitHub page的时候,才会被识别.

生成SSH添加到GitHub

ssh,简单来讲,就是一个秘钥,其中,id_rsa是你这台电脑的私人秘钥,不能给别人看的,id_rsa.pub是公共秘钥,可以随便给别人看。把这个公钥放在GitHub上,这样当你链接GitHub自己的账户时,它就会根据公钥匹配你的私钥,当能够相互匹配时,才能够顺利的通过git上传你的文件到GitHub上。

打开git bash,输入

<span style="color:#333333"><span style="color:#3300aa">git</span> config <span style="color:#0000cc">--global</span> user.name <span style="color:#aa1111">"yourname"</span>
<span style="color:#3300aa">git</span> config <span style="color:#0000cc">--global</span> user.email <span style="color:#aa1111">"youremail"</span></span>

这里的yourname输入你的GitHub用户名,youremail输入你GitHub的邮箱。这样GitHub才能知道你是不是对应它的账户。

检查一下你有没有输对

<span style="color:#333333"><span style="color:#3300aa">git</span> config user.name
<span style="color:#3300aa">git</span> config user.email</span>

创建SSH,一路回车即可

<span style="color:#333333">ssh-keygen <span style="color:#0000cc">-t</span> rsa <span style="color:#0000cc">-C</span> <span style="color:#aa1111">"youremail"</span></span>

打开C:\Users\用户\.ssh\id_rsa.pub, 复制内容

在github的用户设置里,找到SSH and GPG keys,点击New SSH key

Title随意,将复制内容填入Key,点击New SSH key

查看是否成功

<span style="color:#333333"><span style="color:#3300aa">ssh</span> <span style="color:#0000cc">-T</span> <span style="color:#3300aa">git</span>@github.com</span>

参考:

  1. hexo史上最全搭建教程Fangzh的技术博客-CSDN博客hexo

将hexo部署到GitHub

打开myblog文件夹下的站点配置文件_config.yml

找到代码并修改

<span style="color:#333333"><span style="color:#221199">deploy</span><span style="color:#555555">:</span>
<span style="color:#221199">  type</span><span style="color:#555555">: </span>git
<span style="color:#221199">  repo</span><span style="color:#555555">: </span>https<span style="color:#555555">:</span>//github.com/YourgithubName/YourgithubName.github.io.git
<span style="color:#221199">  branch</span><span style="color:#555555">: </span>master</span>

repo: 仓库名,可直接在你创建的仓库复制,有三种,复制后粘贴即可

branch:准备部署的分支,一般使用main,可随意填写

如下为我的配置

<span style="color:#333333"><span style="color:#aa5500"># Deployment</span>
<span style="color:#aa5500">## Docs: https://hexo.io/docs/one-command-deployment</span>
<span style="color:#221199">deploy</span><span style="color:#555555">:</span>
<span style="color:#221199">  type</span><span style="color:#555555">: </span>git
<span style="color:#221199">  repo</span><span style="color:#555555">: </span>git@github.com<span style="color:#555555">:</span>Liuzh25/Liuzh25.github.io.git,main</span>

安装deploy-git ,也就是部署的命令,这样你才能用命令部署到GitHub

<span style="color:#333333"><span style="color:#3300aa">npm</span> install hexo-deployer-git <span style="color:#0000cc">--save</span></span>

部署命令

<span style="color:#333333">hexo clean
hexo generate
hexo deploy</span>

其中 hexo clean清除了你之前生成的东西,也可以不加。 hexo generate 顾名思义,生成静态文章,可以用 hexo g缩写 hexo deploy 部署文章,可以用hexo d缩写

注意第一次deploy时可能要你输入username和password。

等待

进入 http://yourname.github.io ,如果显示为空白,而不是404,说明你已经部署成功,请等待1-4小时

设置个人域名(了解)

注册一个阿里云账户,在阿里云上买一个域名

实名认证

在域名控制台点解析进去

添加如下

即将www.jxxb.topjxxb.top均指向yourname.github.io

不推荐指向IP地址

然后,修改github仓库设置如下

最后一步

<span style="color:#333333">hexo clean
hexo g
hexo d</span>

写文章

Hexo支持makedown语言,这是一种轻量级的标记语言,类似于html,为你的文章添加文字格式及图片,音频,链接等,文件名后缀.md

语法可在Markdown 中文网或者Markdown 教程 | 菜鸟教程查看

推荐使用Typora文本编辑器

git bash输入下列代码

<span style="color:#333333">hexo new abc</span>

即在\myblog\source\_posts文件夹下创建abc.md文件并预先输入信息

使用文本编辑器或者记事本打开编辑即可

编辑完毕,部署至网页

<span style="color:#333333">hexo clean
hexo g
hexo d</span>

参考:

  1. Markdown 中文网

  2. Typora官网

安装NexT

安装「主题」

/myblog 启动Git bash

<span style="color:#333333">git clone https://github.com/theme-next/hexo-theme-next themes/next</span>

启用「主题」

编辑 站点配置文件 _config.yml (位于根目录)

<span style="color:#333333">theme: next</span>

Hexo 站点配置文件/_config.yml)与 NexT主题配置文件(/themes/next/_config.yml)备份

将主题配置文件独立出来

hexo-next的更新不够人性化,且 Hexo 站点配置文件/_config.yml)与 NexT主题配置文件(/themes/next/_config.yml)的割裂使得配置时体验也不算太好

因此现在有四种配置方法,参考官方文档DATA-FILES.md

  1. 直接在Hexo 站点配置文件NexT主题配置文件内编写

    优点: 当在本地预览(hexo s)时,更改后可实时查看,不需要再操作git bash(退出本地预览并再次进入)

  2. NexT主题配置文件内override: false(默认),从站点配置文件主题配置文件中复制你需要更改的条目至/myblog/source/_data/next.yml,如果没有就新建,通常是没有的.

    缺点: 某些插件只能从站点配置文件读取选项

  3. NexT主题配置文件内override: false改为true,将主题配置文件中全部内容复制到next.yml,在Hexo 站点配置文件next.yml内编写

  4. 确认next.yml文件不存在,存在要删除或改名,然后将站点配置文件主题配置文件中复制的你需要更改的条目,即方法2的内容向右移两个空格,在这些参数最上方添加一行 theme_config:,放置于站点配置文件末尾.如下

    # Deployment
    ## Docs: https://hexo.io/docs/one-command-deployment
    deploy:type: gitrepo: git@github.com:Liuzh25/Liuzh25.github.io.git,maintheme_config:# 自定义文件custom_file_path:#head: source/_data/head.swig#header: source/_data/header.swig#sidebar: source/_data/sidebar.swig#postMeta: source/_data/post-meta.swig#postBodyEnd: source/_data/post-body-end.swig#footer: source/_data/footer.swig#bodyEnd: source/_data/body-end.swig#variable: source/_data/variables.styl#mixin: source/_data/mixins.stylstyle: source/_data/styles.styl# ---------------------------------------------------------------# 网站信息设置# ---------------------------------------------------------------# 头像favicon:small: /uploads/favicon-16x16-next.pngmedium: /uploads/favicon-32x32-next.png

    推荐使用方法2或4,这里我使用的方法2,并且只将主题配置文件复制到next.yml

参考:

  1. hexo-theme-next/DATA-FILES.md at master · theme-next/hexo-theme-next

编辑站点配置文件

编辑下列代码如下所示

<span style="color:#333333"># Site
title: 机械细胞
subtitle: 三十功名尘与土,八千里路云和月
description: 三十功名尘与土,八千里路云和月
keywords: 个人,博客
author: 谨礼
language: zh-CN
timezone: Asia/Shanghai# URL
## Set your site url here. For example, if you use GitHub Page, set url as 'https://username.github.io/project'
url: https://www.jxxb.top</span>

参考:

  1. Hexo+NexT(二):Hexo站点配置详解_Guide2IT-CSDN博客

  2. hexo config.yml站点配置文件说明猫狗记-CSDN博客

博客个性化初试

GitHub Corners「图标角」

粘贴代码到themes/next/layout/_layout.swig文件中(放在<div class="headband"></div>的下面),并把href改为你的github地址,将style="fill:#151513; color:#fff改为你喜欢的颜色.

最新版本NexT主题支持GitHub Corners

编辑 主题配置文件 _config.yml(复制到next.yml,方法2)

<span style="color:#333333"># GitHub corner.
github_banner:enable: truepermalink: https://github.com/Liuzh25title: 欢迎访问我的GitHub主页</span>

编辑后发现在网页右上角,且颜色为黑白色,准备更改

按F12后如下图

用红圈内按键指向GitHub Corners,显示如下

点击mian.css:1180,打开mian.css,复制如下代码

<span style="color:#333333">.github-corner svg {border: 0;color: #fff;fill: #222;position: absolute;right: 0;top: 0;z-index: 1000;
}</span>

打开GitHub Corners (tholman.com),对比代码,会发现右边和左边的区别是

<span style="color:#333333">- right: 0;
+ left: 0;
+ transform: scale(-1, 1);</span>

编辑/myblog/source/_data/styles.styl文件添加下列代码

<span style="color:#333333">.github-corner svg {border: 0;color: #fff;fill: #FD6C6C;position: absolute;left: 0;transform: scale(-1, 1);top: 0;z-index: 1000;
}</span>

主题配置文件style代码注释#去掉.(复制到next.yml,方法2)

<span style="color:#333333">custom_file_path:#head: source/_data/head.swig#header: source/_data/header.swig#sidebar: source/_data/sidebar.swig#postMeta: source/_data/post-meta.swig#postBodyEnd: source/_data/post-body-end.swig#footer: source/_data/footer.swig#bodyEnd: source/_data/body-end.swig#variable: source/_data/variables.styl#mixin: source/_data/mixins.stylstyle: source/_data/styles.styl</span>

参考:

  1. GitHub Corners (tholman.com)

  2. 科学上最令人舒服的十种颜色(RGB)

  3. Color Hex Color Codes

图标角延伸知识

使用F12找到对应的css文件,并在/_data/styles.styl文件内重写,用于个性化自己的网站

参考:

  1. 基于Hexo搭建个人博客——进阶篇(从入门到入土) | ookamiAntD's Blog

编辑NexT主题配置文件

设置「网站标签图标」和「页脚」

/myblog/source下创建文件夹,将16x16及32x32的任意图像格式文件放入,并在代码内填写路径

亦可以使用链接

图标的使用方法请阅读下一条

编辑 主题配置文件 _config.yml(复制到next.yml,方法2)

<span style="color:#333333"># ---------------------------------------------------------------
# 网站信息设置
# ---------------------------------------------------------------# 头像
favicon:small: /uploads/favicon-16x16-next.pngmedium: /uploads/favicon-32x32-next.png#apple_touch_icon: /images/apple-touch-icon-next.png#safari_pinned_tab: /images/logo.svg#android_manifest: /images/manifest.json#ms_browserconfig: /images/browserconfig.xml# 页脚
footer:# 指定网站设置的日期,如果没有定义,则使用当前时间.since: 2021# 图标,位于时间和版权信息之间.icon:name: fab fa-ravelry# 如果你想要动画图标,设置它为true.animated: true# 改变图标的颜色,使用十六进制代码.color: "#dada1"# 如果没有定义,将在Hexo主配置中使用' author '.copyright: 机械细胞# 控制(由 Hexo 强力驱动)是否显示powered: false#版权信息
creative_commons:license: by-nc-sasidebar: truepost: truelanguage: deed.zh</span>

图标的选用

NexT 默认使用 Font Awesome 库作为 icon 库,美中不足的是,有一些中国的社交网站的图标在 Font Awesome 库中并没有提供,包括我们熟悉的哔哩哔哩、豆瓣、简书等等。所以如果想使用这些图标,就需要我们使用本地图标进行手动添加。

首先,在 阿里巴巴矢量图标库 之类的网站找到你需要的图标,下载 SVG 格式文件。在/myblog/source新建文件夹,并放入.

编辑 source/_data/styles.styl文件,编辑代码

示例代码

.fa-ravelry {background: url(iconfont/ravelry.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-home{background: url(/iconfont/home-orange.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-about{background: url(/iconfont/about-purple.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-commonweal{background: url(/iconfont/commonweal-green.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-archive{background: url(/iconfont/archive-blue.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-tags{background: url(/iconfont/tags.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-categories{background: url(/iconfont/categories.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-github{background: url(/iconfont/github.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-email{background: url(/iconfont/email.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-qq{background: url(/iconfont/qq.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-baidu{background: url(/iconfont/baidu.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-qqduihua{background: url(/iconfont/qqduihua.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-zhihu{background: url(/iconfont/zhihu.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-bilibili{background: url(/iconfont/bilibili.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-csdn{background: url(/iconfont/csdn.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-gitee{background: url(/iconfont/gitee.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-leetcode{background: url(/iconfont/leetcode.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-link{background: url(/iconfont/link.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-video{background: url(/iconfont/video.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-music{background: url(/iconfont/music.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-photo{background: url(/iconfont/photo.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}
//
.fa-book{background: url(/iconfont/book.svg);background-position: 50% 75%;background-repeat: no-repeat;height: 1rem;width: 1rem;
}

主题配置文件custom_file_path:style代码注释#去掉.(如果你之前没有这么做)

最后一步,引用.

<span style="color:#333333">name: fab fa-ravelry</span>

Font Awesome 的图标引用方式有fa,fab,fad,far,fal等,每种类型可能有相应图标,也可能没有所以如果出现图标叠加,请换引用方式或者图标名,推荐更改图标名.fa-xxx,其中,fa-不能省略,可能出错,我暂时不会改

参考:

  1. 阿里巴巴矢量图标库

  2. Hexo + NexT 通过自定义样式添加 Bilibili 图标_R先生一天不学习就浑身难受-CSDN博客

  3. Hexo博客之优雅使用阿里iconfont图标_小康博客-CSDN博客

  4. Hexo-使用阿里iconfont图标

设置「布局风格」

编辑 主题配置文件 _config.yml(复制到next.yml,方法2)

将你需用启用的scheme前面注释 # 去除即可。

<span style="color:#333333"># ---------------------------------------------------------------
# 布局设置
# ---------------------------------------------------------------# 布局
#scheme: Muse
#scheme: Mist
#scheme: Pisces
scheme: Gemini</span>

添加「菜单项」

fab后面的图标是我自己下载并添加的,参考条目8

badges控制的是归档,标签,分类旁边是否显示统计数

若要添加自定义菜单项,直接插入,并在/themes/next/languages/zh_CN中添加对应代码

编辑 主题配置文件 _config.yml(复制到next.yml,方法2)

<span style="color:#333333"># ---------------------------------------------------------------
# 菜单设置
# ---------------------------------------------------------------# 菜单
# 格式: `Key: /link/ || icon`
menu:home: / || fab fa-hometags: /tags/ || fab fa-tagscategories: /categories/ || fab fa-categoriesarchives: /archives/ || fab fa-archivevideos: /videos/ || fab fa-videomusic: /music/ || fab fa-musicphotos: /photos/ || fab fa-photobooks: /videos/ || fab fa-book#schedule: /schedule/ || fab fa-calendar#sitemap: /sitemap.xml || fab fa-sitemapcommonweal: /404/ || fab fa-commonwealabout: /about/ || fab fa-about# 启用/禁用菜单图标/项目徽章.
menu_settings:icons: truebadges: true</span>

编辑zh-CN.yml

<span style="color:#333333">menu:home: 首页archives: 归档categories: 分类tags: 标签music: 音乐videos: 视频books: 图书photos: 照片about: 关于search: 搜索schedule: 日程表sitemap: 站点地图commonweal: 公益 404</span>

设置「侧栏」

  1. 侧栏位置

  2. 侧栏头像

  3. 添加社交链接

  4. 添加友链

  5. 侧边栏目录设置

编辑 主题配置文件 _config.yml(复制到next.yml,方法2)

<span style="color:#333333"># ---------------------------------------------------------------
# 侧边栏设置
# ---------------------------------------------------------------sidebar:# 侧栏位置.position: left#position: right# 自定义侧栏宽度,默认如下:Muse | Mist: 320  Pisces | Gemini: 240#width: 300# 侧栏顶部填充像素.padding: 18# 侧栏与菜单栏和文档的像素偏移offset: 12# 侧栏头像
avatar:url: /uploads/avatar.jpeg# 头像显示圆形.rounded: true# 鼠标放置时头像旋转.rotated: true# 日志/分类/标签在侧边栏.
site_state: false# 社交链接
# 格式: `关键字: 链接 || 图标名`
social:GitHub: https://github.com/Liuzh25 || fa fa-githubE-Mail: 786189861@qq.com || fa fa-emailQQ: tencent://message/?uin=1095652242 || fa fa-qqQQ对话: tencent://Message/?Uin=786189861&websiteName=www.oicqzone.com&Menu=yes || fa fa-qqduihuaCSDN: https://blog.csdn.net/qq_37828104 || fa fa-csdn码云: https://gitee.com/Liuzh25 || fab fa-gitee力扣: https://leetcode-cn.com/u/liuzh25/ || fab fa-leetcode哔哩哔哩: https://space.bilibili.com/500942397 || fab fa-bilibili知乎: https://www.zhihu.com/people/jin-li-22-85 || fa fa-zhihu百度: http://www.baidu.com || fab fa-baidu# `enable` 控制是否显示图标 ,`icons_only` 控制是否隐藏关键字, `transition` 暂时不懂.
social_icons:enable: trueicons_only: falsetransition: false# 友情链接
links_settings:icon: fab fa-linktitle: 友情链接# 链接排列方式#layout: blocklayout: inlinelinks:野生程序员: http://www.yscxy.net/又见苍岚: https://www.zywvvd.com/小丁的个人博客: https://tding.top/Moorez: http://shenzekun.cn/橘子味雪糕: https://www.liuxianl.com/# 侧边栏目录
toc:enable: fasle# 自动添加列表号到toc.number: false# 标题过长换行.wrap: false# 所有目录全部显示.expand_all: false# 最大标题深度.max_depth: 6</span>

添加「打赏」和「字数统计」

字数统计功能依赖于 https://github.com/theme-next/hexo-symbols-count-time

<span style="color:#333333">npm install hexo-symbols-count-time</span>

编辑 主题配置文件 _config.yml(复制到next.yml,方法2)

<span style="color:#333333"># ---------------------------------------------------------------
# 站点设置
# ---------------------------------------------------------------# 自动摘录描述在主页作为序言文本.
excerpt_description: true# 显示阅读全文.
read_more_btn: true# 文章数据显示
post_meta:item_text: true # 标题显示created_at: true # 创建时间updated_at: # 更新时间enable: trueanother_day: truecategories: true # 分类显示# 字数统计
symbols_count_time:separated_meta: trueitem_text_post: trueitem_text_total: true# 标签,使用图标代替符号#
tag_icon: true# 打赏
reward_settings:enable: trueanimation: false#comment: 赞赏一杯咖啡reward:alipay: /uploads/alipay.jpgwechatpay: /uploads/wechatpay.jpg#paypal: /images/paypal.png#bitcoin: /images/bitcoin.png# 通过Telegram Channel、Twitter等订阅
# 格式: `Key: permalink || icon` (Font Awesome)
follow_me:#Twitter: https://twitter.com/username || fab fa-twitter#Telegram: https://t.me/channel_name || fab fa-telegramWeChat:  /uploads/wechat-qcode.jpg || fab fa-weixin#RSS: /atom.xml || fa fa-rss# 相关热门文章链接
related_posts:enable: falsetitle: # Custom header, leave empty to use the default onedisplay_in_home: falseparams:maxCount: 5#PPMixingRate: 0.0#isDate: false#isImage: false#isExcerpt: false# 文章编辑
post_edit:enable: trueurl: https://github.com/Liuzh25/Liuzh25.github.io/tree/source # 查看源链接#url: https://github.com/user-name/repo-name/edit/branch-name/subdirectory-name # 编辑链接分支# 显示前一篇文章和下一篇文章
post_navigation: left
#post_navigation: right
#post_navigation: false</span>

设置「谷歌日历」和「标签云」

谷歌日历设置失败

编辑 主题配置文件 _config.yml(复制到next.yml,方法2)

<span style="color:#333333"># ---------------------------------------------------------------
# 自定义页面设置
# ---------------------------------------------------------------# 标签页标签云设置.
tagcloud:min: 12 # 字体最小 in pxmax: 30 # 字体最大 in pxstart: "#ccc" # 开始颜色 (hex, rgba, hsla or color keywords)end: "#111" # 结束颜色 (hex, rgba, hsla or color keywords)amount: 200 # 标签最大数量# 谷歌日历
calendar:calendar_id: # liuzhgq1995@gmail.comapi_key: # bGl1emhncTE5OTVAZ21haWwuY29torderBy: startTimeoffsetMax: 24 # Time RangeoffsetMin: 4 # Time RangeshowDeleted: falsesingleEvents: truemaxResults: 250</span>

自定义「logo,代码块,阅读进度条,书签」等

编辑 主题配置文件 _config.yml(复制到next.yml,方法2)

<span style="color:#333333"># ---------------------------------------------------------------
# 杂项布局设置
# ---------------------------------------------------------------# 设置文章/页面的文本对齐方式.
text_align:# 取值: start | end | left | right | center | justify | justify-all | match-parentdesktop: justifymobile: justify# 缩小设备上的padding / margin缩进.
mobile_layout_economy: false# Android Chrome header panel color ($brand-bg / $headband-bg => $black-deep).
android_chrome_color: "#222"# 自定义Logo (不支持 scheme Mist)
custom_logo: /uploads/custom-logo.jpgcodeblock:# 代码高亮主题# 取值范围: normal | night | night eighties | night blue | night bright | solarized | solarized dark | galactichighlight_theme: normal# 代码块复制按钮copy_button:enable: true# 显示文本复制结果.show_result: true# 取值: default | flat | macstyle: macback2top:enable: true# 在侧边栏显示返回顶部.sidebar: false# 返回顶部箭头显示百分比.scrollpercent: true# 阅读进度条
reading_progress:enable: true# 取值: top | bottomposition: topcolor: "#FD6C6C"height: 3px# 书签支持
bookmark:enable: true# 自定义书签的颜色.color: "#64CEAA"# If auto, 关闭页面或单击书签图标时保存阅读进度.# If manual, 只需点击书签图标来保存.save: auto# GitHub corner.
github_banner:enable: truepermalink: https://github.com/Liuzh25title: 欢迎访问我的GitHub主页</span>

设置「字符间空格,图片缩放」

编辑 主题配置文件 _config.yml(复制到next.yml,方法2)

<span style="color:#333333"># ---------------------------------------------------------------
# 第三方插件和服务设置
# ---------------------------------------------------------------# 盘古支持,自动在中文和英文、数字、符号之间添加空格.
# For more information: https://github.com/vinta/pangu.js
pangu: true# 图片缩放.
# For more information: https://github.com/francoischalifour/medium-zoom
mediumzoom: true# 懒加载图像.
# For more information: https://github.com/ApoorvSaxena/lozad.js
lazyload: true# 快速加载页面.
# Dependencies: https://github.com/theme-next/theme-next-pjax
pjax: true</span>

添加「评论」

多评论支持在设置多个评论系统为true时启动

不推荐gittalk评论系统,仅说下如何设置

github设置内开发人员设置OAuth Apps

Application name: 应用名称,随意 Homepage URL: 网站URL,对应自己博客地址 Application description :描述,随意 Authorization callback URL:# 网站URL,博客地址就好 点击注册,页面会出现其中Client ID和Client Secret在后面的配置中需要用到,到时复制粘贴即可:

编辑 主题配置文件 _config.yml(复制到next.yml,方法2)

<span style="color:#333333"># ---------------------------------------------------------------
# 评论设置
# ---------------------------------------------------------------# 多评论系统支持
comments:# 取值: tabs | buttonsstyle: tabs# 选择默认显示的评论系统.# 取值: changyan | disqus | disqusjs | gitalk | livere | valineactive: gitalk# If true, 记住访客选择的评论系统.storage: true# 懒加载所有评论系统.lazyload: true# 修改文本或命令的任何navs.nav:#disqus:#  text: Load Disqus#  order: -1#gitalk:#  order: -2# 畅言
changyan:enable: falseappid: cyvs0PiIkappkey: a868a79f4480491e7870339ebcbcd8b7#post_meta_order: 0# Valine
# For more information: https://valine.js.org, https://github.com/xCss/Valine
valine:enable: falseappid: S0ExOBWoQQYlRlqOT9dAhkTP-gzGzoHszappkey: 7EKLluWPKYoO83sAWtUnwu0Hnotify: false # 邮件通知verify: false # 验证码placeholder: Just go go # 评论框占位符avatar: mm # 个人风格guest_info: nick,mail,link # Custom comment headerpageSize: 10 # Pagination sizelanguage: # Language, available values: en, zh-cnvisitor: true # 文章阅读统计comment_count: true # If false, 评论计数将只显示在发布页面,而不是主页recordIP: true # 是否记录评论者IPserverURLs: # When the custom domain name is enabled, fill it in here (it will be detected automatically by default, no need to fill in)#post_meta_order: 0# Gitalk评论系统
# For more information: https://gitalk.github.io, https://github.com/gitalk/gitalk
gitalk:enable: truegithub_id: Liuzh25 # GitHub用户名repo: Liuzh25.github.io # 仓库名client_id: 415feb380f28706a3d9e # GitHub Application Client IDclient_secret: 8e23474fec2292126310cebde51d90df21869e9e # GitHub Application Client Secretadmin_user: Liuzh25 # GitHub的回购所有者和合作者,只有这些人可以初始化GitHub问题distraction_free_mode: true # 专注模式# Gitalk的显示语言取决于用户的浏览器或系统环境# 如果你想让每个访问你网站的人都看到统一的语言,你可以设置一个强制语言值# 取值: en | es-ES | fr | ru | zh-CN | zh-TWlanguage: zh-CN</span>

参考:

  1. GitTalk评论配置_Madridcrls7的博客-CSDN博客

设置「百度统计分析」

  1. 登录 百度统计,以站长身份注册,进入管理-代码管理-代码获取页面

  2. 复制 hm.js? 后面那串统计脚本 id.

编辑 主题配置文件 _config.yml(复制到next.yml,方法2)

<span style="color:#333333"># ---------------------------------------------------------------
# 统计和分析
# ---------------------------------------------------------------# Baidu Analytics
baidu_analytics: 2f80625c255f4d995edcdcf2ad0a5201</span>

参考:

  1. 百度统计——领先的中文网站分析平台 (baidu.com)

添加「本地搜索」

编辑 主题配置文件 _config.yml(复制到next.yml,方法2)

<span style="color:#333333"># ---------------------------------------------------------------
# 搜索服务
# ---------------------------------------------------------------# 本地搜索
local_search:enable: true# If auto, 则通过更改输入触发搜索.# If manual, 按下输入键或搜索按钮触发搜索.trigger: auto# 每篇文章显示前n个结果,设置为-1显示所有结果top_n_per_article: 1# 将html字符串转换为可读字符串.unescape: false# P在页面加载时预加载搜索数据.preload: false</span>

设置「动画」

设置顶部加载动画

<span style="color:#333333">git clone https://github.com/theme-next/theme-next-pace source/lib/pace</span>

设置背景动画

<span style="color:#333333">git clone https://github.com/theme-next/theme-next-three source/lib/three</span>

编辑 主题配置文件 _config.yml(复制到next.yml,方法2)

<span style="color:#333333"># ---------------------------------------------------------------
# 动画设置
# ---------------------------------------------------------------# Progress bar in the top during page loading.
# Dependencies: https://github.com/theme-next/theme-next-pace
# For more information: https://github.com/HubSpot/pace
pace:enable: true# Themes list:# big-counter | bounce | barber-shop | center-atom | center-circle | center-radar | center-simple# corner-indicator | fill-left | flat-top | flash | loading-bar | mac-osx | material | minimaltheme: bounce# JavaScript 3D library.
# Dependencies: https://github.com/theme-next/theme-next-three
three:enable: falsethree_waves: truecanvas_lines: falsecanvas_sphere: false</span>

博客配置进阶

添加「页面」

  1. 新建页面

    在Hexo 站点目录下。使用 hexo new page 新建一个页面,命名,例如

    hexo new page link
  2. 设置页面类型

    在index.md中添加一行type,例如

    ---
    title: link
    date: 2021-04-27 09:57:29
    type: "link"
    comments: false
    ---
  3. 修改菜单项

    编辑 主题配置文件 _config.yml,在菜单中添加链接.(复制到next.yml,方法2)

  4. categories,archives,tags,about,commonweal等菜单添加页面

设置「腾讯公益404页面」

腾讯公益404页面,寻找丢失儿童,让大家一起关注此项公益事业!

新建 404.html 页面,放到 /myblog/source 目录下,内容如下:

<span style="color:#333333"><!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>404</title><link rel="alternate" href="/atom.xml" title="机械细胞" type="application/atom+xml">
</head><body><script type="text/javascript" src="//qzonestyle.gtimg.cn/qzone/hybrid/app/404/search_children.js" charset="utf-8" homePageUrl="/" homePageName="返回"></script> </body>
</html></span>

实现「鼠标点击效果」和添加「鼠标跟随粒子特效」

编辑 主题配置文件 _config.yml,添加动态配置项,并取消 body-end.swig 的注释(复制到next.yml,方法2)

我将其放在了动画效果下面

<span style="color:#333333"># 鼠标点击效果
cursor_effect:enabled: truetype: fireworks  # fireworks:礼花 | explosion:爆炸 | love:浮出爱心 | text:浮出文字fairyDustCursor: true  # 鼠标跟随粒子特效</span>

新建body-end.swig ,添加如下代码:

<span style="color:#333333">{# 鼠标点击特效 #}
{% if theme.cursor_effect.enabled and not is_index %}{% if theme.cursor_effect.fairyDustCursor %}<script src="/js/cursor/fairyDustCursor.js"></script>{% endif %}{% if theme.cursor_effect.type == "fireworks" %}<script src="/js/cursor/fireworks.js"></script>{% elseif theme.cursor_effect.type == "explosion" %}<canvas class="fireworks" style="position: fixed;left: 0;top: 0;z-index: 1; pointer-events: none;" ></canvas><script src="//cdn.bootcss.com/animejs/2.2.0/anime.min.js"></script><script src="/js/cursor/explosion.min.js"></script>{% elseif theme.cursor_effect.type == "love" %}<script src="/js/cursor/love.min.js"></script>{% elseif theme.cursor_effect.type == "text" %}<script src="/js/cursor/text.js"></script>{% endif %}
{% endif %}</span>

将以下5个 JS 文件复制到目录 /myblog/source/js/cursor/

fireworks.js

示例代码

class Circle {constructor({ origin, speed, color, angle, context }) {this.origin = originthis.position = { ...this.origin }this.color = colorthis.speed = speedthis.angle = anglethis.context = contextthis.renderCount = 0}draw() {this.context.fillStyle = this.colorthis.context.beginPath()this.context.arc(this.position.x, this.position.y, 2, 0, Math.PI * 2)this.context.fill()}move() {this.position.x = (Math.sin(this.angle) * this.speed) + this.position.xthis.position.y = (Math.cos(this.angle) * this.speed) + this.position.y + (this.renderCount * 0.3)this.renderCount++}
}class Boom {constructor ({ origin, context, circleCount = 16, area }) {this.origin = originthis.context = contextthis.circleCount = circleCountthis.area = areathis.stop = falsethis.circles = []}randomArray(range) {const length = range.lengthconst randomIndex = Math.floor(length * Math.random())return range[randomIndex]}randomColor() {const range = ['8', '9', 'A', 'B', 'C', 'D', 'E', 'F']return '#' + this.randomArray(range) + this.randomArray(range) + this.randomArray(range) + this.randomArray(range) + this.randomArray(range) + this.randomArray(range)}randomRange(start, end) {return (end - start) * Math.random() + start}init() {for(let i = 0; i < this.circleCount; i++) {const circle = new Circle({context: this.context,origin: this.origin,color: this.randomColor(),angle: this.randomRange(Math.PI - 1, Math.PI + 1),speed: this.randomRange(1, 6)})this.circles.push(circle)}}move() {this.circles.forEach((circle, index) => {if (circle.position.x > this.area.width || circle.position.y > this.area.height) {return this.circles.splice(index, 1)}circle.move()})if (this.circles.length == 0) {this.stop = true}}draw() {this.circles.forEach(circle => circle.draw())}
}class CursorSpecialEffects {constructor() {this.computerCanvas = document.createElement('canvas')this.renderCanvas = document.createElement('canvas')this.computerContext = this.computerCanvas.getContext('2d')this.renderContext = this.renderCanvas.getContext('2d')this.globalWidth = window.innerWidththis.globalHeight = window.innerHeightthis.booms = []this.running = false}handleMouseDown(e) {const boom = new Boom({origin: { x: e.clientX, y: e.clientY },context: this.computerContext,area: {width: this.globalWidth,height: this.globalHeight}})boom.init()this.booms.push(boom)this.running || this.run()}handlePageHide() {this.booms = []this.running = false}init() {const style = this.renderCanvas.stylestyle.position = 'fixed'style.top = style.left = 0style.zIndex = '999999999999999999999999999999999999999999'style.pointerEvents = 'none'style.width = this.renderCanvas.width = this.computerCanvas.width = this.globalWidthstyle.height = this.renderCanvas.height = this.computerCanvas.height = this.globalHeightdocument.body.append(this.renderCanvas)window.addEventListener('mousedown', this.handleMouseDown.bind(this))window.addEventListener('pagehide', this.handlePageHide.bind(this))}run() {this.running = trueif (this.booms.length == 0) {return this.running = false}requestAnimationFrame(this.run.bind(this))this.computerContext.clearRect(0, 0, this.globalWidth, this.globalHeight)this.renderContext.clearRect(0, 0, this.globalWidth, this.globalHeight)this.booms.forEach((boom, index) => {if (boom.stop) {return this.booms.splice(index, 1)}boom.move()boom.draw()})this.renderContext.drawImage(this.computerCanvas, 0, 0, this.globalWidth, this.globalHeight)}
}const cursorSpecialEffects = new CursorSpecialEffects()
cursorSpecialEffects.init()

explosion.min.js

示例代码

"use strict";function updateCoords(e){pointerX=(e.clientX||e.touches[0].clientX)-canvasEl.getBoundingClientRect().left,pointerY=e.clientY||e.touches[0].clientY-canvasEl.getBoundingClientRect().top}function setParticuleDirection(e){var t=anime.random(0,360)*Math.PI/180,a=anime.random(50,180),n=[-1,1][anime.random(0,1)]*a;return{x:e.x+n*Math.cos(t),y:e.y+n*Math.sin(t)}}function createParticule(e,t){var a={};return a.x=e,a.y=t,a.color=colors[anime.random(0,colors.length-1)],a.radius=anime.random(16,32),a.endPos=setParticuleDirection(a),a.draw=function(){ctx.beginPath(),ctx.arc(a.x,a.y,a.radius,0,2*Math.PI,!0),ctx.fillStyle=a.color,ctx.fill()},a}function createCircle(e,t){var a={};return a.x=e,a.y=t,a.color="#F00",a.radius=0.1,a.alpha=0.5,a.lineWidth=6,a.draw=function(){ctx.globalAlpha=a.alpha,ctx.beginPath(),ctx.arc(a.x,a.y,a.radius,0,2*Math.PI,!0),ctx.lineWidth=a.lineWidth,ctx.strokeStyle=a.color,ctx.stroke(),ctx.globalAlpha=1},a}function renderParticule(e){for(var t=0;t<e.animatables.length;t++){e.animatables[t].target.draw()}}function animateParticules(e,t){for(var a=createCircle(e,t),n=[],i=0;i<numberOfParticules;i++){n.push(createParticule(e,t))}anime.timeline().add({targets:n,x:function(e){return e.endPos.x},y:function(e){return e.endPos.y},radius:0.1,duration:anime.random(1200,1800),easing:"easeOutExpo",update:renderParticule}).add({targets:a,radius:anime.random(80,160),lineWidth:0,alpha:{value:0,easing:"linear",duration:anime.random(600,800)},duration:anime.random(1200,1800),easing:"easeOutExpo",update:renderParticule,offset:0})}function debounce(e,t){var a;return function(){var n=this,i=arguments;clearTimeout(a),a=setTimeout(function(){e.apply(n,i)},t)}}var canvasEl=document.querySelector(".fireworks");if(canvasEl){var ctx=canvasEl.getContext("2d"),numberOfParticules=30,pointerX=0,pointerY=0,tap="mousedown",colors=["#FF1461","#18FF92","#5A87FF","#FBF38C"],setCanvasSize=debounce(function(){canvasEl.width=2*window.innerWidth,canvasEl.height=2*window.innerHeight,canvasEl.style.width=window.innerWidth+"px",canvasEl.style.height=window.innerHeight+"px",canvasEl.getContext("2d").scale(2,2)},500),render=anime({duration:1/0,update:function(){ctx.clearRect(0,0,canvasEl.width,canvasEl.height)}});document.addEventListener(tap,function(e){"sidebar"!==e.target.id&&"toggle-sidebar"!==e.target.id&&"A"!==e.target.nodeName&&"IMG"!==e.target.nodeName&&(render.play(),updateCoords(e),animateParticules(pointerX,pointerY))},!1),setCanvasSize(),window.addEventListener("resize",setCanvasSize,!1)}"use strict";function updateCoords(e){pointerX=(e.clientX||e.touches[0].clientX)-canvasEl.getBoundingClientRect().left,pointerY=e.clientY||e.touches[0].clientY-canvasEl.getBoundingClientRect().top}function setParticuleDirection(e){var t=anime.random(0,360)*Math.PI/180,a=anime.random(50,180),n=[-1,1][anime.random(0,1)]*a;return{x:e.x+n*Math.cos(t),y:e.y+n*Math.sin(t)}}function createParticule(e,t){var a={};return a.x=e,a.y=t,a.color=colors[anime.random(0,colors.length-1)],a.radius=anime.random(16,32),a.endPos=setParticuleDirection(a),a.draw=function(){ctx.beginPath(),ctx.arc(a.x,a.y,a.radius,0,2*Math.PI,!0),ctx.fillStyle=a.color,ctx.fill()},a}function createCircle(e,t){var a={};return a.x=e,a.y=t,a.color="#F00",a.radius=0.1,a.alpha=0.5,a.lineWidth=6,a.draw=function(){ctx.globalAlpha=a.alpha,ctx.beginPath(),ctx.arc(a.x,a.y,a.radius,0,2*Math.PI,!0),ctx.lineWidth=a.lineWidth,ctx.strokeStyle=a.color,ctx.stroke(),ctx.globalAlpha=1},a}function renderParticule(e){for(var t=0;t<e.animatables.length;t++){e.animatables[t].target.draw()}}function animateParticules(e,t){for(var a=createCircle(e,t),n=[],i=0;i<numberOfParticules;i++){n.push(createParticule(e,t))}anime.timeline().add({targets:n,x:function(e){return e.endPos.x},y:function(e){return e.endPos.y},radius:0.1,duration:anime.random(1200,1800),easing:"easeOutExpo",update:renderParticule}).add({targets:a,radius:anime.random(80,160),lineWidth:0,alpha:{value:0,easing:"linear",duration:anime.random(600,800)},duration:anime.random(1200,1800),easing:"easeOutExpo",update:renderParticule,offset:0})}function debounce(e,t){var a;return function(){var n=this,i=arguments;clearTimeout(a),a=setTimeout(function(){e.apply(n,i)},t)}}var canvasEl=document.querySelector(".fireworks");if(canvasEl){var ctx=canvasEl.getContext("2d"),numberOfParticules=30,pointerX=0,pointerY=0,tap="mousedown",colors=["#FF1461","#18FF92","#5A87FF","#FBF38C"],setCanvasSize=debounce(function(){canvasEl.width=2*window.innerWidth,canvasEl.height=2*window.innerHeight,canvasEl.style.width=window.innerWidth+"px",canvasEl.style.height=window.innerHeight+"px",canvasEl.getContext("2d").scale(2,2)},500),render=anime({duration:1/0,update:function(){ctx.clearRect(0,0,canvasEl.width,canvasEl.height)}});document.addEventListener(tap,function(e){"sidebar"!==e.target.id&&"toggle-sidebar"!==e.target.id&&"A"!==e.target.nodeName&&"IMG"!==e.target.nodeName&&(render.play(),updateCoords(e),animateParticules(pointerX,pointerY))},!1),setCanvasSize(),window.addEventListener("resize",setCanvasSize,!1)};

love.min.js

示例代码

!function(e,t,a){function n(){c(".heart{width: 10px;height: 10px;position: fixed;background: #f00;transform: rotate(45deg);-webkit-transform: rotate(45deg);-moz-transform: rotate(45deg);}.heart:after,.heart:before{content: '';width: inherit;height: inherit;background: inherit;border-radius: 50%;-webkit-border-radius: 50%;-moz-border-radius: 50%;position: fixed;}.heart:after{top: -5px;}.heart:before{left: -5px;}"),o(),r()}function r(){for(var e=0;e<d.length;e++)d[e].alpha<=0?(t.body.removeChild(d[e].el),d.splice(e,1)):(d[e].y--,d[e].scale+=.004,d[e].alpha-=.013,d[e].el.style.cssText="left:"+d[e].x+"px;top:"+d[e].y+"px;opacity:"+d[e].alpha+";transform:scale("+d[e].scale+","+d[e].scale+") rotate(45deg);background:"+d[e].color+";z-index:99999");requestAnimationFrame(r)}function o(){var t="function"==typeof e.onclick&&e.onclick;e.οnclick=function(e){t&&t(),i(e)}}function i(e){var a=t.createElement("div");a.className="heart",d.push({el:a,x:e.clientX-5,y:e.clientY-5,scale:1,alpha:1,color:s()}),t.body.appendChild(a)}function c(e){var a=t.createElement("style");a.type="text/css";try{a.appendChild(t.createTextNode(e))}catch(t){a.styleSheet.cssText=e}t.getElementsByTagName("head")[0].appendChild(a)}function s(){return"rgb("+~~(255*Math.random())+","+~~(255*Math.random())+","+~~(255*Math.random())+")"}var d=[];e.requestAnimationFrame=function(){return e.requestAnimationFrame||e.webkitRequestAnimationFrame||e.mozRequestAnimationFrame||e.oRequestAnimationFrame||e.msRequestAnimationFrame||function(e){setTimeout(e,1e3/60)}}(),n()}(window,document);

text.js

示例代码

var a_idx = 0;
jQuery(document).ready(function($) {$("body").click(function(e) {var a = new Array("富强", "民主", "文明", "和谐", "自由", "平等", "公正" ,"法治", "爱国", "敬业", "诚信", "友善");var $i = $("<span/>").text(a[a_idx]);var x = e.pageX,y = e.pageY;$i.css({"z-index": 99999,"top": y - 28,"left": x - a[a_idx].length * 8,"position": "absolute","color": "#ff7a45"});$("body").append($i);$i.animate({"top": y - 180,"opacity": 0}, 1500, function() {$i.remove();});a_idx = (a_idx + 1) % a.length;});
});

fairyDustCursor.js

示例代码


/*!* Fairy Dust Cursor.js* - 90's cursors collection* -- https://github.com/tholman/90s-cursor-effects* -- http://codepen.io/tholman/full/jWmZxZ/*/(function fairyDustCursor() {var possibleColors = ["#D61C59", "#E7D84B", "#1B8798"]var width = window.innerWidth;var height = window.innerHeight;var cursor = {x: width/2, y: width/2};var particles = [];function init() {bindEvents();loop();}// Bind events that are neededfunction bindEvents() {document.addEventListener('mousemove', onMouseMove);document.addEventListener('touchmove', onTouchMove);document.addEventListener('touchstart', onTouchMove);window.addEventListener('resize', onWindowResize);}function onWindowResize(e) {width = window.innerWidth;height = window.innerHeight;}function onTouchMove(e) {if( e.touches.length > 0 ) {for( var i = 0; i < e.touches.length; i++ ) {addParticle( e.touches[i].clientX, e.touches[i].clientY, possibleColors[Math.floor(Math.random()*possibleColors.length)]);}}}function onMouseMove(e) {    cursor.x = e.clientX;cursor.y = e.clientY;addParticle( cursor.x, cursor.y, possibleColors[Math.floor(Math.random()*possibleColors.length)]);}function addParticle(x, y, color) {var particle = new Particle();particle.init(x, y, color);particles.push(particle);}function updateParticles() {// Updatedfor( var i = 0; i < particles.length; i++ ) {particles[i].update();}// Remove dead particlesfor( var i = particles.length -1; i >= 0; i-- ) {if( particles[i].lifeSpan < 0 ) {particles[i].die();particles.splice(i, 1);}}}function loop() {requestAnimationFrame(loop);updateParticles();}/*** Particles*/function Particle() {this.character = "*";this.lifeSpan = 120; //msthis.initialStyles ={"position": "fixed","top": "0", //必须加"display": "block","pointerEvents": "none","z-index": "10000000","fontSize": "20px","will-change": "transform"};// Init, and set propertiesthis.init = function(x, y, color) {this.velocity = {x:  (Math.random() < 0.5 ? -1 : 1) * (Math.random() / 2),y: 1};this.position = {x: x - 10, y: y - 20};this.initialStyles.color = color;console.log(color);this.element = document.createElement('span');this.element.innerHTML = this.character;applyProperties(this.element, this.initialStyles);this.update();document.body.appendChild(this.element);};this.update = function() {this.position.x += this.velocity.x;this.position.y += this.velocity.y;this.lifeSpan--;this.element.style.transform = "translate3d(" + this.position.x + "px," + this.position.y + "px,0) scale(" + (this.lifeSpan / 120) + ")";}this.die = function() {this.element.parentNode.removeChild(this.element);}}/*** Utils*/// Applies css `properties` to an element.function applyProperties( target, properties ) {for( var key in properties ) {target.style[ key ] = properties[ key ];}}init();
})();

http://localhost:4000/无效果,关闭本地预览, hexo clean ,hexo s.

参考:

  1. 给Hexo(next主题)博客加上stackexchange愚人节鼠标跟随特效

  2. Hexo博客+Next主题鼠标点击特效

修改「文章内链接文本样式」

编辑/myblog/source/_data/styles.styl,添加

<span style="color:#333333">// 文章内链接文本样式
if hexo-config("post_body_a.enable").post-bodya{color: convert(hexo-config("post_body_a.normal_color"));border-bottom: none;&:hover {color: convert(hexo-config("post_body_a.hover_color"));text-decoration: underline;}}</span>

编辑 主题配置文件 _config.yml,添加动态配置项(复制到next.yml,方法2)

<span style="color:#333333"># 文章内链接文本样式
post_body_a:enable: truenormal_color: "#0593d3"hover_color: "#0477ab"</span>

参考:

  1. 修改文章内链接样式 | hexo_好好编程的博客-CSDN博客

修改「小代码块自定义样式」

编辑/myblog/source/_data/styles.styl,添加.

<span style="color:#333333">// 小代码块的自定义样式
code {color: #ff7600;background: #fbf7f8;margin: 2px;
}
.highlight, code {border: 1px solid #d6d6d6;
}</span>

添加「文章加密访问」

编辑 主题配置文件 _config.yml,取消 head.swig 的注释(复制到next.yml,方法2)

新建head.swig文件,填入下列代码

<span style="color:#333333"><script>(function () {if ('{{ page.password }}') {if (prompt('请输入文章密码') !== '{{ page.password }}') {alert('密码错误!');if (history.length === 1) {location.replace("http://www.jxxb.top"); // 这里替换成你的首页} else {history.back();}}}})();
</script></span>

在文章标题添加password,如下

<span style="color:#333333">title: Hexo 搭配 GitHub 建立博客, 选用 nexT 主题
date: 2021-04-26 19:21:20
categories:
- [兴趣, 网站, 博客]
tags:
- Hexo
- Git
password: 123</span>

设置「文章置顶」

修改 hero-generator-index 插件,把文件:node_modules/hexo-generator-index/lib/generator.js 内的代码替换为:

<span style="color:#333333">'use strict';
var pagination = require('hexo-pagination');
module.exports = function(locals){var config = this.config;var posts = locals.posts;posts.data = posts.data.sort(function(a, b) {if(a.top && b.top) { // 两篇文章top都有定义if(a.top == b.top) return b.date - a.date; // 若top值一样则按照文章日期降序排else return b.top - a.top; // 否则按照top值降序排}else if(a.top && !b.top) { // 以下是只有一篇文章top有定义,那么将有top的排在前面(这里用异或操作居然不行233)return -1;}else if(!a.top && b.top) {return 1;}else return b.date - a.date; // 都没定义按照文章日期降序排});var paginationDir = config.pagination_dir || 'page';return pagination('', posts, {perPage: config.index_generator.per_page,layout: ['index', 'archive'],format: paginationDir + '/%d/',data: {__index: true}});
};</span>

在文章标题添加top,如下

<span style="color:#333333">title: Hexo 搭配 GitHub 建立博客, 选用 nexT 主题
date: 2021-04-26 19:21:20
categories:
- [兴趣, 网站, 博客]
tags:
- Hexo
- Git
password:
top: 100</span>

添加「侧栏已运行时间」

编辑 主题配置文件 _config.yml,取消 sidebar.swig 的注释(复制到next.yml,方法2)

新建sidebar.swig文件,填入下列代码

<span style="color:#333333"><div id="days"></div><script>function show_date_time(){window.setTimeout("show_date_time()", 1000);BirthDay=new Date("04/23/2021 23:24:52");today=new Date();timeold=(today.getTime()-BirthDay.getTime());sectimeold=timeold/1000secondsold=Math.floor(sectimeold);msPerDay=24*60*60*1000e_daysold=timeold/msPerDaydaysold=Math.floor(e_daysold);e_hrsold=(e_daysold-daysold)*24;hrsold=setzero(Math.floor(e_hrsold));e_minsold=(e_hrsold-hrsold)*60;minsold=setzero(Math.floor((e_hrsold-hrsold)*60));seconds=setzero(Math.floor((e_minsold-minsold)*60));document.getElementById('days').innerHTML="已运行"+daysold+"天"+hrsold+"小时"+minsold+"分"+seconds+"秒";}
function setzero(i){if (i<10){i="0" + i};return i;
}
show_date_time();
</script></span>

_data/styles.styl中添加

<span style="color:#333333">// 自定义的侧栏时间样式
#days {display: block;color: #19caad;font-size: 14px;margin-left: 15px;
}</span>

最后,修改BirthDay=new Date("01/10/2017 12:34:56");, color: #fffa74;, margin-top: 15px;等等

添加「萌萌的宠物」

git bash输入

<span style="color:#333333">npm install -save hexo-helper-live2d</span>

hexo_config.yml中添加参数(必须是站点配置文件)

<span style="color:#333333">live2d:enable: truescriptFrom: localpluginRootPath: live2dw/pluginJsPath: lib/pluginModelPath: assets/model:use: live2d-widget-model-wankodisplay:position: rightwidth: 150height: 300mobile:show: true</span>

添加「“本文结束”标记」

编辑 主题配置文件 _config.yml,添加动态配置项,并取消 post-body-end.swig 的注释(复制到next.yml,方法2)

<span style="color:#333333"># 文章末尾添加“本文结束”标记
passage_end_tag:enabled: true</span>

新建post-body-end.swig文件,填入下列代码

<span style="color:#333333"><div>{% if theme.passage_end_tag.enabled and not is_index %}<div style="text-align:center;color: #ccc;font-size:25px;">-------------本文结束<i class="fa fa-paw"></i>感谢您的阅读-------------</div>{% endif %}
</div></span>

添加「APlayer音乐播放器」

download

点击访问Aplayer源码:GitHub Aplayer。下载到本地,解压后将dist文件夹复制到/mybolg/source文件夹下并重命名为aplayer

music.js

新建/mybolg/source/dist/music.js文件,添加内容:

<span style="color:#333333">const ap = new APlayer({container: document.getElementById('aplayer'),listFolded: false,listMaxHeight: 90,lrcType: 3,audio: [{name: "暗涌",artist: '王菲',url: 'http://www.ytmp3.cn/down/52980.mp3',cover: 'http://p1.music.126.net/w8RFsMH8VJfPsBmVudYGsA==/109951163020569833.jpg?param=130y130',lrc: 'lrc.lrc'},{name: 'Wonderful U',artist: 'AGA',url: 'http://www.ytmp3.cn/down/51181.mp3',cover: 'http://p1.music.126.net/Blb_Gi0AJTWIEBLr189F4A==/18791753232142320.jpg?param=130y130',},{name: '浮夸',artist: '陈奕迅',url: 'http://www.ytmp3.cn/down/49639.mp3',cover: 'http://p1.music.126.net/Bl1hEdJbMSj5YJsTqUjr-w==/109951163520311175.jpg?param=130y130',}]
});
</span>

源码参数解释APlayer 中文文档

audio对应的便是音频文件,所以音乐播放器需要播放的音乐是需要自己进行相关信息(如歌曲链接、歌词、封面等)的配置。这里放一个mp3音乐外链网站:http://up.mcyt.net/ ,搜索对应的音乐,然后复制url和右击封面图片链接粘贴到对应的位置上就行了。

编辑body-end.swig,将下列代码填入

<span style="color:#333333"><link rel="stylesheet" href="/aplayer/APlayer.min.css">
<div id="aplayer"></div>
<script type="text/javascript" src="/aplayer/APlayer.min.js"></script>
<script type="text/javascript" src="/aplayer/music.js"></script></span>

参考:

  1. hexo4.0 - Next7.2.4 主题优化配置_xiaohu的博客-CSDN博客

  2. APlayer 中文文档

引用jquery

发现动态标签页没法使用了,查了一下,需要引用jquery.

编辑body-end.swig,在首行添加代码

<span style="color:#333333">{# 引用JQ #}
<script type="text/javascript" src="//libs.baidu.com/jquery/1.8.3/jquery.min.js"></script></span>

动态标签页

新建/myblog/source/js/src/dytitle.js,填入下列代码

<span style="color:#333333">var OriginTitile = document.title;
var titleTime;
document.addEventListener('visibilitychange', function () {if (document.hidden) {$('[rel="shortcut icon"]').attr('href', "/TEP.png");document.title = '程序已暂停';clearTimeout(titleTime);}else {$('[rel="shortcut icon"]').attr('href', "/favicon.png");document.title = '程序运行中 ' + OriginTitile;titleTime = setTimeout(function () {document.title = OriginTitile;}, 2000);}
});</span>

编辑body-end.swig,追加代码

<span style="color:#333333"><script type="text/javascript" src="/js/src/dytitle.js"></script></span>

雪花特效

编辑 主题配置文件 _config.yml,添加动态配置项(复制到next.yml,方法2)

<span style="color:#333333"># 雪花飘落特效
snow:enabled: true#type: hexo#type: circletype: sakura</span>

编辑body-end.swig,添加代码

<span style="color:#333333"><!-- 雪花飘落特效 -->
{% if theme.snow.enabled and not is_index %}{% if theme.snow.type == "hexo" %}<script type="text/javascript">var windowWidth = $(window).width();if (windowWidth > 480) {document.write('<script type="text/javascript" src="/js/src/hexo.js"><\/script>');}</script>{% elseif theme.snow.type == "circle" %}}<script type="text/javascript">var windowWidth = $(window).width();if (windowWidth > 480) {document.write('<script type="text/javascript" src="/js/src/circle.js"><\/script>');}</script>{% elseif theme.snow.type == "sakura" %}}<script type="text/javascript" src="/js/src/sakura.js"><\/script>{% endif %}
{% endif %}</span>

/myblog/source/js/src文件夹新建.js文件

hexo.js

示例代码

/*样式一*/
(function($){$.fn.snow = function(options){var $flake = $('<div id="snowbox" />').css({'position': 'absolute','z-index':'9999', 'top': '-50px'}).html('❄'),documentHeight     = $(document).height(),documentWidth   = $(document).width(),defaults = {minSize     : 10,maxSize        : 20,newOn      : 1000,flakeColor   : "#AFDAEF" /* 此处可以定义雪花颜色,若要白色可以改为#FFFFFF */},options  = $.extend({}, defaults, options);var interval= setInterval( function(){var startPositionLeft = Math.random() * documentWidth - 100,startOpacity = 0.5 + Math.random(),sizeFlake = options.minSize + Math.random() * options.maxSize,endPositionTop = documentHeight - 200,endPositionLeft = startPositionLeft - 500 + Math.random() * 500,durationFall = documentHeight * 10 + Math.random() * 5000;$flake.clone().appendTo('body').css({left: startPositionLeft,opacity: startOpacity,'font-size': sizeFlake,color: options.flakeColor}).animate({top: endPositionTop,left: endPositionLeft,opacity: 0.2},durationFall,'linear',function(){$(this).remove()});}, options.newOn);};
})(jQuery);
$(function(){$.fn.snow({ minSize: 5, /* 定义雪花最小尺寸 */maxSize: 50,/* 定义雪花最大尺寸 */newOn: 300  /* 定义密集程度,数字越小越密集 */});
});

circle.js

示例代码

/*样式二*/
/* 控制下雪 */
function snowFall(snow) {/* 可配置属性 */snow = snow || {};this.maxFlake = snow.maxFlake || 200;   /* 最多片数 */this.flakeSize = snow.flakeSize || 10;  /* 雪花形状 */this.fallSpeed = snow.fallSpeed || 1;   /* 坠落速度 */
}
/* 兼容写法 */
requestAnimationFrame = window.requestAnimationFrame ||window.mozRequestAnimationFrame ||window.webkitRequestAnimationFrame ||window.msRequestAnimationFrame ||window.oRequestAnimationFrame ||function(callback) { setTimeout(callback, 1000 / 60); };cancelAnimationFrame = window.cancelAnimationFrame ||window.mozCancelAnimationFrame ||window.webkitCancelAnimationFrame ||window.msCancelAnimationFrame ||window.oCancelAnimationFrame;
/* 开始下雪 */
snowFall.prototype.start = function(){/* 创建画布 */snowCanvas.apply(this);/* 创建雪花形状 */createFlakes.apply(this);/* 画雪 */drawSnow.apply(this)
}
/* 创建画布 */
function snowCanvas() {/* 添加Dom结点 */var snowcanvas = document.createElement("canvas");snowcanvas.id = "snowfall";snowcanvas.width = window.innerWidth;snowcanvas.height = document.body.clientHeight;snowcanvas.setAttribute("style", "position:absolute; top: 0; left: 0; z-index: 1; pointer-events: none;");document.getElementsByTagName("body")[0].appendChild(snowcanvas);this.canvas = snowcanvas;this.ctx = snowcanvas.getContext("2d");/* 窗口大小改变的处理 */window.onresize = function() {snowcanvas.width = window.innerWidth;/* snowcanvas.height = window.innerHeight */}
}
/* 雪运动对象 */
function flakeMove(canvasWidth, canvasHeight, flakeSize, fallSpeed) {this.x = Math.floor(Math.random() * canvasWidth);   /* x坐标 */this.y = Math.floor(Math.random() * canvasHeight);  /* y坐标 */this.size = Math.random() * flakeSize + 2;          /* 形状 */this.maxSize = flakeSize;                           /* 最大形状 */this.speed = Math.random() * 1 + fallSpeed;         /* 坠落速度 */this.fallSpeed = fallSpeed;                         /* 坠落速度 */this.velY = this.speed;                             /* Y方向速度 */this.velX = 0;                                      /* X方向速度 */this.stepSize = Math.random() / 30;                 /* 步长 */this.step = 0                                       /* 步数 */
}
flakeMove.prototype.update = function() {var x = this.x,y = this.y;/* 左右摆动(余弦) */this.velX *= 0.98;if (this.velY <= this.speed) {this.velY = this.speed}this.velX += Math.cos(this.step += .05) * this.stepSize;this.y += this.velY;this.x += this.velX;/* 飞出边界的处理 */if (this.x >= canvas.width || this.x <= 0 || this.y >= canvas.height || this.y <= 0) {this.reset(canvas.width, canvas.height)}
};
/* 飞出边界-放置最顶端继续坠落 */
flakeMove.prototype.reset = function(width, height) {this.x = Math.floor(Math.random() * width);this.y = 0;this.size = Math.random() * this.maxSize + 2;this.speed = Math.random() * 1 + this.fallSpeed;this.velY = this.speed;this.velX = 0;
};
// 渲染雪花-随机形状(此处可修改雪花颜色!!!)
flakeMove.prototype.render = function(ctx) {var snowFlake = ctx.createRadialGradient(this.x, this.y, 0, this.x, this.y, this.size);snowFlake.addColorStop(0, "rgba(255, 255, 255, 0.9)");  /* 此处是雪花颜色,默认是白色 */snowFlake.addColorStop(.5, "rgba(255, 255, 255, 0.5)"); /* 若要改为其他颜色,请自行查 */snowFlake.addColorStop(1, "rgba(255, 255, 255, 0)");    /* 找16进制的RGB 颜色代码。 */ctx.save();ctx.fillStyle = snowFlake;ctx.beginPath();ctx.arc(this.x, this.y, this.size, 0, Math.PI * 2);ctx.fill();ctx.restore();
};
/* 创建雪花-定义形状 */
function createFlakes() {var maxFlake = this.maxFlake,flakes = this.flakes = [],canvas = this.canvas;for (var i = 0; i < maxFlake; i++) {flakes.push(new flakeMove(canvas.width, canvas.height, this.flakeSize, this.fallSpeed))}
}
/* 画雪 */
function drawSnow() {var maxFlake = this.maxFlake,flakes = this.flakes;ctx = this.ctx, canvas = this.canvas, that = this;/* 清空雪花 */ctx.clearRect(0, 0, canvas.width, canvas.height);for (var e = 0; e < maxFlake; e++) {flakes[e].update();flakes[e].render(ctx);}/*  一帧一帧的画 */this.loop = requestAnimationFrame(function() {drawSnow.apply(that);});
}
/* 调用及控制方法 */
var snow = new snowFall({maxFlake:60});
snow.start();

sakura.js

示例代码

         var stop, staticx;var img = new Image();img.src = "";function Sakura(x, y, s, r, fn) {this.x = x;this.y = y;this.s = s;this.r = r;this.fn = fn;}Sakura.prototype.draw = function(cxt) {cxt.save();var xc = 40 * this.s / 4;cxt.translate(this.x, this.y);cxt.rotate(this.r);cxt.drawImage(img, 0, 0, 40 * this.s, 40 * this.s)cxt.restore();}Sakura.prototype.update = function() {this.x = this.fn.x(this.x, this.y);this.y = this.fn.y(this.y, this.y);this.r = this.fn.r(this.r);if(this.x > window.innerWidth ||this.x < 0 ||this.y > window.innerHeight ||this.y < 0) {this.r = getRandom('fnr');if(Math.random() > 0.4) {this.x = getRandom('x');this.y = 0;this.s = getRandom('s');this.r = getRandom('r');} else {this.x = window.innerWidth;this.y = getRandom('y');this.s = getRandom('s');this.r = getRandom('r');}}}SakuraList = function() {this.list = [];}SakuraList.prototype.push = function(sakura) {this.list.push(sakura);}SakuraList.prototype.update = function() {for(var i = 0, len = this.list.length; i < len; i++) {this.list[i].update();}}SakuraList.prototype.draw = function(cxt) {for(var i = 0, len = this.list.length; i < len; i++) {this.list[i].draw(cxt);}}SakuraList.prototype.get = function(i) {return this.list[i];}SakuraList.prototype.size = function() {return this.list.length;}function getRandom(option) {var ret, random;switch(option) {case 'x':ret = Math.random() * window.innerWidth;break;case 'y':ret = Math.random() * window.innerHeight;break;case 's':ret = Math.random();break;case 'r':ret = Math.random() * 6;break;case 'fnx':random = -0.5 + Math.random() * 1;ret = function(x, y) {return x + 0.5 * random - 1.7;};break;case 'fny':random = 1.5 + Math.random() * 0.7ret = function(x, y) {return y + random;};break;case 'fnr':random = Math.random() * 0.03;ret = function(r) {return r + random;};break;}return ret;}function startSakura() {requestAnimationFrame = window.requestAnimationFrame ||window.mozRequestAnimationFrame ||window.webkitRequestAnimationFrame ||window.msRequestAnimationFrame ||window.oRequestAnimationFrame;var canvas = document.createElement('canvas'),cxt;staticx = true;canvas.height = window.innerHeight;canvas.width = window.innerWidth;canvas.setAttribute('style', 'position: fixed;left: 0;top: 0;pointer-events: none;');canvas.setAttribute('id', 'canvas_sakura');document.getElementsByTagName('body')[0].appendChild(canvas);cxt = canvas.getContext('2d');var sakuraList = new SakuraList();for(var i = 0; i < 50; i++) {var sakura, randomX, randomY, randomS, randomR, randomFnx, randomFny;randomX = getRandom('x');randomY = getRandom('y');randomR = getRandom('r');randomS = getRandom('s');randomFnx = getRandom('fnx');randomFny = getRandom('fny');randomFnR = getRandom('fnr');sakura = new Sakura(randomX, randomY, randomS, randomR, {x: randomFnx,y: randomFny,r: randomFnR});sakura.draw(cxt);sakuraList.push(sakura);}stop = requestAnimationFrame(function() {cxt.clearRect(0, 0, canvas.width, canvas.height);sakuraList.update();sakuraList.draw(cxt);stop = requestAnimationFrame(arguments.callee);})}window.onresize = function() {var canvasSnow = document.getElementById('canvas_snow');canvasSnow.width = window.innerWidth;canvasSnow.height = window.innerHeight;}img.onload = function() {startSakura();}function stopp() {if(staticx) {var child = document.getElementById("canvas_sakura");child.parentNode.removeChild(child);window.cancelAnimationFrame(stop);staticx = false;} else {startSakura();}}​        

参考:

  1. Hexo中NexT主题添加雪花飘落效果_DonLex 的博客-CSDN博客

  2. html从零开始——为网页加入樱花飘落效果不会java不改名的博客-CSDN博客html樱花飘落代码复制

心知天气插件

  1. 注册心知天气

  2. 控制台-产品管理-添加产品(免费版)

  3. 新版插件-选择产品

  4. 配置插件-获取代码-将代码填入head.swig,填到其他位置也行

  5. 为插件配置动态加载项,如下

    <!-- 心知天气 -->
    {% if theme.weather_widget.enabled and not is_index %}<div id="tp-weather-widget"></div><script>(function(a,h,g,f,e,d,c,b){b=function(){d=h.createElement(g);c=h.getElementsByTagName(g)[0];d.src=e;d.charset="utf-8";d.async=1;c.parentNode.insertBefore(d,c)};a["SeniverseWeatherWidgetObject"]=f;a[f]||(a[f]=function(){(a[f].q=a[f].q||[]).push(arguments)});a[f].l=+new Date();if(a.attachEvent){a.attachEvent("onload",b)}else{a.addEventListener("load",b,false)}}(window,document,"script","SeniverseWeatherWidget","//cdn.sencdn.com/widget2/static/js/bundle.js?t="+parseInt((new Date().getTime() / 100000000).toString(),10)));window.SeniverseWeatherWidget('show', {flavor: "bubble",location: "WM7B0X53DZW2",geolocation: true,language: "zh-Hans",unit: "c",theme: "auto",token: "6f2b0ab7-4bda-4cbe-8ee0-50d827246f1c",hover: "enabled",container: "tp-weather-widget"})</script>
    {% endif %}
  6. 编辑 主题配置文件 _config.yml,添加动态配置项(复制到next.yml,方法2)

    #心知天气
    weather_widget:enabled: true

参考:

  1. 站点配置更新 | Don Lex

  2. 心知天气

打字特效

编辑 主题配置文件 _config.yml,添加动态配置项(复制到next.yml,方法2)

<span style="color:#333333"># 打字特效
typing_effect:enabled: truecolorful: true  # 礼花特效shake: true  # 震动特效</span>

编辑body-end.swig ,添加如下代码:

<span style="color:#333333"><!-- 打字特效 -->
{% if theme.typing_effect.enabled and not is_index %}<script src="/js/src/activate-power-mode.min.js"></script><script>POWERMODE.colorful = {{ theme.typing_effect.colorful }};POWERMODE.shake = {{ theme.typing_effect.shake }};document.body.addEventListener('input', POWERMODE);</script>
{% endif %}</span>

新建/myblog/source/js/src/activate-power-mode.min.js,添加下列代码

示例代码

(function webpackUniversalModuleDefinition(root, factory) {if(typeof exports === 'object' && typeof module === 'object')module.exports = factory();else if(typeof define === 'function' && define.amd)define([], factory);else if(typeof exports === 'object')exports["POWERMODE"] = factory();elseroot["POWERMODE"] = factory();
})(this, function() {
return /******/ (function(modules) { // webpackBootstrap
/******/    // The module cache
/******/    var installedModules = {};/******/     // The require function
/******/    function __webpack_require__(moduleId) {/******/        // Check if module is in cache
/******/        if(installedModules[moduleId])
/******/            return installedModules[moduleId].exports;/******/      // Create a new module (and put it into the cache)
/******/        var module = installedModules[moduleId] = {
/******/            exports: {},
/******/            id: moduleId,
/******/            loaded: false
/******/        };/******/      // Execute the module function
/******/        modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);/******/        // Flag the module as loaded
/******/        module.loaded = true;/******/      // Return the exports of the module
/******/        return module.exports;
/******/    }/******/   // expose the modules object (__webpack_modules__)
/******/    __webpack_require__.m = modules;/******/   // expose the module cache
/******/    __webpack_require__.c = installedModules;/******/  // __webpack_public_path__
/******/    __webpack_require__.p = "";/******/  // Load entry module and return exports
/******/    return __webpack_require__(0);
/******/ })
/************************************************************************/
/******/ ([
/* 0 */
/***/ (function(module, exports, __webpack_require__) {'use strict';var canvas = document.createElement('canvas');canvas.width = window.innerWidth;canvas.height = window.innerHeight;canvas.style.cssText = 'position:fixed;top:0;left:0;pointer-events:none;z-index:999999';window.addEventListener('resize', function () {canvas.width = window.innerWidth;canvas.height = window.innerHeight;});document.body.appendChild(canvas);var context = canvas.getContext('2d');var particles = [];var particlePointer = 0;var rendering = false;POWERMODE.shake = true;function getRandom(min, max) {return Math.random() * (max - min) + min;}function getColor(el) {if (POWERMODE.colorful) {var u = getRandom(0, 360);return 'hsla(' + getRandom(u - 10, u + 10) + ', 100%, ' + getRandom(50, 80) + '%, ' + 1 + ')';} else {return window.getComputedStyle(el).color;}}function getCaret() {var el = document.activeElement;var bcr;if (el.tagName === 'TEXTAREA' ||(el.tagName === 'INPUT' && el.getAttribute('type') === 'text')) {var offset = __webpack_require__(1)(el, el.selectionEnd);bcr = el.getBoundingClientRect();return {x: offset.left + bcr.left,y: offset.top + bcr.top,color: getColor(el)};}var selection = window.getSelection();if (selection.rangeCount) {var range = selection.getRangeAt(0);var startNode = range.startContainer;if (startNode.nodeType === document.TEXT_NODE) {startNode = startNode.parentNode;}bcr = range.getBoundingClientRect();return {x: bcr.left,y: bcr.top,color: getColor(startNode)};}return { x: 0, y: 0, color: 'transparent' };}function createParticle(x, y, color) {return {x: x,y: y,alpha: 1,color: color,velocity: {x: -1 + Math.random() * 2,y: -3.5 + Math.random() * 2}};}function POWERMODE() {{ // spawn particlesvar caret = getCaret();var numParticles = 5 + Math.round(Math.random() * 10);while (numParticles--) {particles[particlePointer] = createParticle(caret.x, caret.y, caret.color);particlePointer = (particlePointer + 1) % 500;}}{ // shake screenif (POWERMODE.shake) {var intensity = 1 + 2 * Math.random();var x = intensity * (Math.random() > 0.5 ? -1 : 1);var y = intensity * (Math.random() > 0.5 ? -1 : 1);document.body.style.marginLeft = x + 'px';document.body.style.marginTop = y + 'px';setTimeout(function() {document.body.style.marginLeft = '';document.body.style.marginTop = '';}, 75);}}if(!rendering){requestAnimationFrame(loop);}};POWERMODE.colorful = false;function loop() {rendering = true;context.clearRect(0, 0, canvas.width, canvas.height);var rendered = false;var rect = canvas.getBoundingClientRect();for (var i = 0; i < particles.length; ++i) {var particle = particles[i];if (particle.alpha <= 0.1) continue;particle.velocity.y += 0.075;particle.x += particle.velocity.x;particle.y += particle.velocity.y;particle.alpha *= 0.96;context.globalAlpha = particle.alpha;context.fillStyle = particle.color;context.fillRect(Math.round(particle.x - 1.5) - rect.left,Math.round(particle.y - 1.5) - rect.top,3, 3);rendered = true;}if(rendered){requestAnimationFrame(loop);}else{rendering = false;}}module.exports = POWERMODE;/***/ }),
/* 1 */
/***/ (function(module, exports) {/* jshint browser: true */(function () {// The properties that we copy into a mirrored div.// Note that some browsers, such as Firefox,// do not concatenate properties, i.e. padding-top, bottom etc. -> padding,// so we have to do every single property specifically.var properties = ['direction',  // RTL support'boxSizing','width',  // on Chrome and IE, exclude the scrollbar, so the mirror div wraps exactly as the textarea does'height','overflowX','overflowY',  // copy the scrollbar for IE'borderTopWidth','borderRightWidth','borderBottomWidth','borderLeftWidth','borderStyle','paddingTop','paddingRight','paddingBottom','paddingLeft',// https://developer.mozilla.org/en-US/docs/Web/CSS/font'fontStyle','fontVariant','fontWeight','fontStretch','fontSize','fontSizeAdjust','lineHeight','fontFamily','textAlign','textTransform','textIndent','textDecoration',  // might not make a difference, but better be safe'letterSpacing','wordSpacing','tabSize','MozTabSize'];var isFirefox = window.mozInnerScreenX != null;function getCaretCoordinates(element, position, options) {var debug = options && options.debug || false;if (debug) {var el = document.querySelector('#input-textarea-caret-position-mirror-div');if ( el ) { el.parentNode.removeChild(el); }}// mirrored divvar div = document.createElement('div');div.id = 'input-textarea-caret-position-mirror-div';document.body.appendChild(div);var style = div.style;var computed = window.getComputedStyle? getComputedStyle(element) : element.currentStyle;  // currentStyle for IE < 9// default textarea stylesstyle.whiteSpace = 'pre-wrap';if (element.nodeName !== 'INPUT')style.wordWrap = 'break-word';  // only for textarea-s// position off-screenstyle.position = 'absolute';  // required to return coordinates properlyif (!debug)style.visibility = 'hidden';  // not 'display: none' because we want rendering// transfer the element's properties to the divproperties.forEach(function (prop) {style[prop] = computed[prop];});if (isFirefox) {// Firefox lies about the overflow property for textareas: https://bugzilla.mozilla.org/show_bug.cgi?id=984275if (element.scrollHeight > parseInt(computed.height))style.overflowY = 'scroll';} else {style.overflow = 'hidden';  // for Chrome to not render a scrollbar; IE keeps overflowY = 'scroll'}div.textContent = element.value.substring(0, position);// the second special handling for input type="text" vs textarea: spaces need to be replaced with non-breaking spaces - http://stackoverflow.com/a/13402035/1269037if (element.nodeName === 'INPUT')div.textContent = div.textContent.replace(/\s/g, "\u00a0");var span = document.createElement('span');// Wrapping must be replicated *exactly*, including when a long word gets// onto the next line, with whitespace at the end of the line before (#7).// The  *only* reliable way to do that is to copy the *entire* rest of the// textarea's content into the <span> created at the caret position.// for inputs, just '.' would be enough, but why bother?span.textContent = element.value.substring(position) || '.';  // || because a completely empty faux span doesn't render at alldiv.appendChild(span);var coordinates = {top: span.offsetTop + parseInt(computed['borderTopWidth']),left: span.offsetLeft + parseInt(computed['borderLeftWidth'])};if (debug) {span.style.backgroundColor = '#aaa';} else {document.body.removeChild(div);}return coordinates;}if (typeof module != "undefined" && typeof module.exports != "undefined") {module.exports = getCaretCoordinates;} else {window.getCaretCoordinates = getCaretCoordinates;}}());/***/ })
/******/ ])
});
;

参考

  1. activate-power-mode

新建文章后自动打开

新建/myblog/scripts文件夹,在文件夹里新建任意名称.js文件,填入下列代码

<span style="color:#333333">var spawn = require('child_process').exec;// Hexo 3 用户复制这段
hexo.on('new', function(data){spawn('start  "D:\Typora\Typora.exe" ' + data.path);
});</span>

参考

  1. Hexo 添加文章时自动打开编辑器 | 苏寅 Blog (suyin-blog.club)

  2. Open markdown file after running hexo new? · Issue #1007 · hexojs/hexo (github.com)

标签云

使用命令行进行安装

<span style="color:#333333">npm install hexo-tag-cloud@^2.0.* --save </span>

编辑/_data/sidebar.swig,在合适的位置填入代码

<span style="color:#333333"><!--标签云 -->
{% if site.tags.length > 1 and theme.tag_cloud.enabled and not is_index %}
<script type="text/javascript" charset="utf-8" src="{{ url_for('/js/tagcloud.js') }}"></script>
<script type="text/javascript" charset="utf-8" src="{{ url_for('/js/tagcanvas.js') }}"></script>
<div class="widget-wrap"><!--<div style="font-family: 'comic sans ms', courier; font-size: 16px;">Tag Cloud</div>--><div id="myCanvasContainer" class="widget tagcloud"><canvas width="250" height="250" id="resCanvas" style="width:100%">{{ list_tags() }}</canvas></div>
</div>
{% endif %}</span>

编辑 主题配置文件 _config.yml,添加动态配置项(复制到next.yml,方法2)

<span style="color:#333333"># 标签云
tag_cloud:enabled: truetextFont: Trebuchet MS, HelveticatextColor: '#333'textHeight: 25outlineColor: '#E2E1D1'maxSpeed: 0.5pauseOnSelected: true # true 意味着当选中对应 tag 时,停止转动 </span>

参考

  1. 站点配置更新 | Don Lex

  2. Hexo博客Next主题建立标签云hexo-tag-cloud及效果展示_AomanHao的博客-CSDN博客

  3. hexo-tag-cloud中文文档

自动备份 Hexo 博客源文件

同样,在 Hexo 根目录的 scripts 文件夹下新建一个 js 文件,文件名随意取,,填入下列代码

<span style="color:#333333">require('shelljs/global');try {hexo.on('deployAfter', function() {//当deploy完成后执行备份run();});
} catch (e) {console.log("产生了一个错误<( ̄3 ̄)> !,错误详情为:" + e.toString());
}function run() {if (!which('git')) {echo('Sorry, this script requires git');exit(1);} else {echo("======================Auto Backup Begin===========================");cd('D:/Code/MyBlog');    //此处修改为Hexo根目录路径if (exec('git add --all').code !== 0) {echo('Error: Git add failed');exit(1);}if (exec('git commit -am "Form auto backup script\'s commit"').code !== 0) {echo('Error: Git commit failed');exit(1);}if (exec('git push origin source').code !== 0) {echo('Error: Git push failed');exit(1);}echo("==================Auto Backup Complete============================")}
}
</span>

注意,修改代码Hexo根目录路径分支名

接着,在命令行输入,安装 shelljs 模块

<span style="color:#333333">npm install --save shelljs</span>

关闭畅言统计

看着不爽

找到changyan.js,找到if post.comments,更改为if post.comments and theme.changyan.comment

随后编辑 主题配置文件 _config.yml(复制到next.yml,方法2)

<span style="color:#333333"># 畅言
changyan:enable: trueappid: cyvs0PiIkappkey: a868a79f4480491e7870339ebcbcd8b7comment: false#post_meta_order: 0</span>

其实不加也行

Tag Plugins

{% cq %}世间所有的相遇,都是久别重逢{% endcq %}

参考

  1. Tag Plugins | Hexo

  2. 内置标签 - NexT 使用文档 (iissnan.com)

  3. Hexo-NexT Tag 插件的使用 | 小丁的个人博客 (tding.top)

首字下沉

编辑style.styl,添加

<span style="color:#333333">// 首字下沉
.post-body>p:first-child::first-letter{float: left;
/* height: 32px;*/margin-top: 14px;margin-right: 6px;color: #555;font-size: 42px;line-height: 28px;font-style: normal;font-weight: 400;+mobile(){margin-top: 10px;margin-right: 4px;font-size: 26px;line-height: 20px;}
}</span>

总结

  1. /myblog/source文件

  2. 编辑themes/next/languages/zh-CN.yml

  3. 站点配置文件 _config.yml

  4. 编辑changyan.js

  5. 设置「文章置顶」

  6. npm install hexo-symbols-count-time

  7. npm install -save hexo-helper-live2d

参考

  1. img 403的解决办法

  2. 又见苍岚

  3. Hexo -13- 利用 Markdown 语法画 flowchart 流程图 | 又见苍岚 (zywvvd.com)

  4. Hexo -10- 使用PicGo配合七牛云图床实现Markdown图像无痛管理 | 又见苍岚 (zywvvd.com)

  5. Hexo-NexT 增加 canvas 粒子时钟 | 小丁的个人博客 (tding.top)

  6. HTML5 Canvas实现会跳舞的时间动画 | HTML5资源教程 (html5tricks.com)

  7. Hexo 加入豆瓣读书页面 | 小丁的个人博客 (tding.top)

  8. Hexo-NexT 实现相册 | 小丁的个人博客 (tding.top)

  9. Hexo NexT主题美化2.0 | Leaface (liaofuzhan.com)

  10. hexo史上最全搭建教程Fangzh的技术博客-CSDN博客hexo

  11. Archive | ookamiAntD's Blog (yangbingdong.com)

  12. 【搜索优化】Hexo-next百度和谷歌搜索优化 | Ehcoo

  13. 打造个性超赞博客 Hexo + NexT + GitHub Pages 的超深度优化 | reuixiy (io-oi.me)

  14. Setting Up Image Storage | imgix Documentation

问题

  1. 无法更换天气位置

  2. 在文章标题下添加热门链接

  3. 侧栏的滚动条隐藏

  4. 长代码折叠

    使用<details>summary></summary></details>隐藏,如下例

    <details><summary><strong>示例代码</strong></summary>```python//这里是示例代码print("hello world")```
    </details>

    效果展示

    示例代码

  5. 启用谷歌日历

  6. 无法更换音乐位置

  7. 无法隐藏歌词

  8. 为博客添加一个首页

Hexo-Next 博客搭建相关推荐

  1. Hexo个人博客搭建教程

    Hexo个人博客搭建教程 1 搭建前准备 1.1 环境配置 需要安装git.node,最后安装hexo 1.1.1 安装Git: 首先看电脑是否已经安装了git $ git 若提示not founde ...

  2. hexo个人博客搭建

    title: hexo个人博客搭建 date: 2020-10-14 21:06:50 tags: 随笔 copyright: false hexo个人博客搭建过程 安装软件 git nodejs t ...

  3. hexo+GitHub博客搭建实战

    我的个人博客链接:wangwlj.com 想要搭建类似的博客吗? 如果是,那就赶快点进来吧-- 手把手教学,现在开始!! PS: 将会在个人博客持续更新,本文链接:hexo+GitHub博客搭建实战. ...

  4. 【个人博客】Hexo个人博客搭建与配置详细教程 + Fluid主题 + Gitee发布

    文章目录 一.环境准备 1.1 安装 NodeJs 1.2 安装 Git 1.3 安装 Hexo 二.Gitee仓库搭建 2.1 Gitee账号注册 2.2 仓库搭建 三.Hexo博客搭建 3.1 基 ...

  5. Github+Hexo+matery博客搭建

    文章目录 前言 主题介绍 一.博客环境搭建 1. 下载Git和Node.js 1.1 Node.js的安装与配置 1.2 Git的安装与配置 二.Github注册以及Github Pages创建 三. ...

  6. Hexo个人博客搭建历程

    环境配置 Github的创建和配置 安装Git 安装Node.js 安装Hexo Hexo主题设置 主题1:stun 安装 使用 更新 本地效果 主题优化 主题2:black-blue 安装 使用 更 ...

  7. 个人网站搭建 03——Hexo + Github 博客搭建

    使用 Github Pages 服务搭建博客的好处有: 全是静态文件,访问速度快: 免费方便,不用花一分钱就可以搭建一个自由的个人博客,不需要服务器不需要后台: 可以随意绑定自己的域名,不仔细看的话根 ...

  8. hexo + gitcafe 博客搭建

    环境: ubuntu 14.04 hexo gitcafe gitcafe是国内的代码托管,支持自定义访问域名,速度相较于github而言要快,hexo是一个快速 简洁且高效的博客框架.Hexo使用M ...

  9. Hexo+Github博客搭建之Matery主题个性化修改篇(一)

    首先声明一下,一定要分清什么是站点配置文件,什么是主题文件,比如我在F盘新建我的博客文件夹,名称为blog,那么站点配置文件的路径为F:/blog/_config.yml,而你的主题配置文件路径为F: ...

  10. hexo个人博客搭建(二)butterfly主题配置

    Butterfly主题安装文档(二)之主题配置 一.回顾安装butterfly主题 1.在hexo项目根目录下执行操作clone主题 git clone -b master https://githu ...

最新文章

  1. XShell连接Deepin
  2. 交换机和路由器各自的实现原理
  3. Scala基础教程(五):函数、闭包
  4. 并行批处理多个文件 matlab
  5. 转:大型网站架构系列:负载均衡详解(2)
  6. 初学者是学习 C 语言还是 C++ 好?各有何利弊?
  7. uber-zap_如何构建自己的Uber-for-X应用程序(PART 2)
  8. linux中对数据怎么降序,Linux系统sort排序命令怎么使用
  9. 处理MathType的兼容问题(下)
  10. 根据身份证号 计算具体年龄
  11. 京东商城发现了一枚Bug
  12. VSCode搭建STM32开发环境(极简自我搭建懒人直接使用插件)
  13. 我承认 IDEA 2021.3 有点强!
  14. 柔性电流传感器(柔性电流探头)的工作原理和特点是什么?
  15. Python-个人笔记-Tensorflow-PINN-Plotting
  16. 你什么也无法告诉别人
  17. 腾讯企业邮箱只能接受消息不能发送
  18. CAS单点登录四-单点登出
  19. PIE-Engine上传矢量数据
  20. 【机器学习】XgBoost 原理详解 数学推导

热门文章

  1. PLC编程基本功:梯形图与控制线路
  2. 2014 ACM/ICPC 北京赛区网络赛解题报告汇总
  3. 微软校招来喽 | 内推名额等待优秀的你
  4. 通过www获取 图片
  5. 什么是继承 继承的好处
  6. 宁德时代发布第一代钠离子电池;霍尼韦尔宣布多项全球性高管人事任命 | 美通社头条...
  7. mysql建表时错误1075_navicat出现错误1075怎么办
  8. 【数据库系统】第一部分 数据库基础(3) 关系数据库标准语言SQL(7) 视图
  9. 3dmax导出fbx之后模型变大
  10. 面向次世代的Windows App SDK 近况