<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
参考:
-
Git - Book (git-scm.com)
-
超详细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
参考:
-
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>
参考:
-
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.top
和jxxb.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>
参考:
-
Markdown 中文网
-
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
-
直接在Hexo 站点配置文件和NexT主题配置文件内编写
优点: 当在本地预览(
hexo s
)时,更改后可实时查看,不需要再操作git bash
(退出本地预览并再次进入) -
NexT主题配置文件内
override: false
(默认),从站点配置文件和主题配置文件中复制你需要更改的条目至/myblog/source/_data/next.yml
,如果没有就新建,通常是没有的.缺点: 某些插件只能从站点配置文件读取选项
-
NexT主题配置文件内
override: false
改为true
,将主题配置文件中全部内容复制到next.yml
,在Hexo 站点配置文件和next.yml内编写 -
确认
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
参考:
-
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>
参考:
-
Hexo+NexT(二):Hexo站点配置详解_Guide2IT-CSDN博客
-
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>
参考:
-
GitHub Corners (tholman.com)
-
科学上最令人舒服的十种颜色(RGB)
-
Color Hex Color Codes
图标角延伸知识
使用F12找到对应的css文件,并在/_data/styles.styl
文件内重写,用于个性化自己的网站
参考:
-
基于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-
不能省略,可能出错,我暂时不会改
参考:
-
阿里巴巴矢量图标库
-
Hexo + NexT 通过自定义样式添加 Bilibili 图标_R先生一天不学习就浑身难受-CSDN博客
-
Hexo博客之优雅使用阿里iconfont图标_小康博客-CSDN博客
-
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>
设置「侧栏」
-
侧栏位置
-
侧栏头像
-
添加社交链接
-
添加友链
-
侧边栏目录设置
编辑 主题配置文件 _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>
参考:
-
GitTalk评论配置_Madridcrls7的博客-CSDN博客
设置「百度统计分析」
-
登录 百度统计,以站长身份注册,进入管理-代码管理-代码获取页面
-
复制 hm.js? 后面那串统计脚本 id.
编辑 主题配置文件 _config.yml(复制到next.yml
,方法2)
<span style="color:#333333"># ---------------------------------------------------------------
# 统计和分析
# ---------------------------------------------------------------# Baidu Analytics
baidu_analytics: 2f80625c255f4d995edcdcf2ad0a5201</span>
参考:
-
百度统计——领先的中文网站分析平台 (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>
博客配置进阶
添加「页面」
-
新建页面
在Hexo 站点目录下。使用
hexo new page
新建一个页面,命名,例如hexo new page link
-
设置页面类型
在index.md中添加一行type,例如
--- title: link date: 2021-04-27 09:57:29 type: "link" comments: false ---
-
修改菜单项
编辑 主题配置文件 _config.yml,在菜单中添加链接.(复制到
next.yml
,方法2) -
为
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
.
参考:
-
给Hexo(next主题)博客加上stackexchange愚人节鼠标跟随特效
-
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>
参考:
-
修改文章内链接样式 | 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>
参考:
-
hexo4.0 - Next7.2.4 主题优化配置_xiaohu的博客-CSDN博客
-
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();}}?
参考:
-
Hexo中NexT主题添加雪花飘落效果_DonLex 的博客-CSDN博客
-
html从零开始——为网页加入樱花飘落效果不会java不改名的博客-CSDN博客html樱花飘落代码复制
心知天气插件
-
注册心知天气
-
控制台-产品管理-添加产品(免费版)
-
新版插件-选择产品
-
配置插件-获取代码-将代码填入
head.swig
,填到其他位置也行 -
为插件配置动态加载项,如下
<!-- 心知天气 --> {% 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 %}
-
编辑 主题配置文件 _config.yml,添加动态配置项(复制到
next.yml
,方法2)#心知天气 weather_widget:enabled: true
参考:
-
站点配置更新 | Don Lex
-
心知天气
打字特效
编辑 主题配置文件 _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;}}());/***/ })
/******/ ])
});
;
参考
-
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>
参考
-
Hexo 添加文章时自动打开编辑器 | 苏寅 Blog (suyin-blog.club)
-
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>
参考
-
站点配置更新 | Don Lex
-
Hexo博客Next主题建立标签云hexo-tag-cloud及效果展示_AomanHao的博客-CSDN博客
-
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 %}
参考
-
Tag Plugins | Hexo
-
内置标签 - NexT 使用文档 (iissnan.com)
-
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>
总结
-
/myblog/source文件
-
编辑themes/next/languages/zh-CN.yml
-
站点配置文件 _config.yml
-
编辑changyan.js
-
设置「文章置顶」
-
npm install hexo-symbols-count-time
-
npm install -save hexo-helper-live2d
参考
-
img 403的解决办法
-
又见苍岚
-
Hexo -13- 利用 Markdown 语法画 flowchart 流程图 | 又见苍岚 (zywvvd.com)
-
Hexo -10- 使用PicGo配合七牛云图床实现Markdown图像无痛管理 | 又见苍岚 (zywvvd.com)
-
Hexo-NexT 增加 canvas 粒子时钟 | 小丁的个人博客 (tding.top)
-
HTML5 Canvas实现会跳舞的时间动画 | HTML5资源教程 (html5tricks.com)
-
Hexo 加入豆瓣读书页面 | 小丁的个人博客 (tding.top)
-
Hexo-NexT 实现相册 | 小丁的个人博客 (tding.top)
-
Hexo NexT主题美化2.0 | Leaface (liaofuzhan.com)
-
hexo史上最全搭建教程Fangzh的技术博客-CSDN博客hexo
-
Archive | ookamiAntD's Blog (yangbingdong.com)
-
【搜索优化】Hexo-next百度和谷歌搜索优化 | Ehcoo
-
打造个性超赞博客 Hexo + NexT + GitHub Pages 的超深度优化 | reuixiy (io-oi.me)
-
Setting Up Image Storage | imgix Documentation
问题
-
无法更换天气位置
-
在文章标题下添加热门链接
-
侧栏的滚动条隐藏
-
长代码折叠
使用
<details>summary></summary></details>
隐藏,如下例<details><summary><strong>示例代码</strong></summary>```python//这里是示例代码print("hello world")``` </details>
效果展示
?示例代码
-
启用谷歌日历
-
无法更换音乐位置
-
无法隐藏歌词
-
为博客添加一个首页