首先我们需要在 Next
主题 _config.xml
中设置一下功能开关,有些默认是开的,有些默认是关的:
首先我们需要在 Next
主题 _config.xml
中设置一下功能开关,有些默认是开的,有些默认是关的:
首先可以在某宝上搜索VG
购买Google Voice账号。下面就记下Google Voice 怎样保号。(如果您有Google语音号码,但在6个月内既没有拨出电话或收到来电,也没有发送或收到短信,则Google会收回该号码。不过,Google不会收回已转携至Google语音服务或申请了永久使用权的号码。)
一些方法:
在终端里输入如下命令:
bash <(curl -sL https://raw.githubusercontent.com/hijkpw/scripts/master/ubuntu_install_v2ray.sh)
<!-- more-->
bash <(curl -sL https://raw.githubusercontent.com/hijkpw/scripts/master/ubuntu_install_v2ray2.sh)
bash <(curl -sL https://raw.githubusercontent.com/hijkpw/scripts/master/centos_install_v2ray.sh)
bash <(curl -sL https://raw.githubusercontent.com/hijkpw/scripts/master/centos_install_v2ray2.sh)
更多脚本: hijkpw /scripts
点“服务器”下拉菜单中的添加“vmess”服务器,出现添加服务器界面
填写服务器地址(域名或ip)、端口、用户id、额外id,加密方式一般都是auto,传输协议一般是tcp(本站的一键脚本都会输出这些信息)。别名随便写就可以,比如“洛杉矶不限流量”。如果使用了伪装等高级技术,需要选择伪装类型(ws伪装类型选none),伪装域名填写配置的主机名,输入伪装路径,底层传输安全选择tls,allowinsecure选择true(没使用伪装不要动这些参数!)
点击主界面上的“参数设置”,在“Core:基础设置”中将“Http代理”选择“开启PAC,并自动配置PAC(PAC模式)”;需要隐藏真实ip,或者某些网站打不开,可使用全局模式(也可以右键托盘图标,在”Http代理“中选择):
接着点击“Core:路由设置”,域名策略选“AsIS”,然后点击“一键设置默认自定义路由规则”,然后点击下方的“确定”完成设置
v2ray一键脚本 运行完后,会输出配置文件路径,默认是 /etc/v2ray/config.json,其内容类似这样:
{
"log": {
"loglevel": "info",
"access": "/var/log/v2ray/access.log",
"error": "/var/log/v2ray/error.log"
},
"inbounds": [{
"port": 12345,
"protocol": "vmess",
"settings": {
"clients": [
{
"id": "6be0aa25-09c1-4d8b-a96f-75cd3485021f",
"level": 1,
"alterId": 53
}
]
}
}],
"outbounds": [{
"protocol": "freedom",
"settings": {}
},{
"protocol": "blackhole",
"settings": {},
"tag": "blocked"
}],
"routing": {
"rules": [
{
"type": "field",
"ip": ["geoip:private"],
"outboundTag": "blocked"
}
]
}
}
下文教程的修改都是参考这个文件,如果出现问题,请注意与原来文件的差异。
v2ray多用户分成两种:同端口不同id,不同端口不同id。v2ray两种类型都支持,接下来分别做介绍。
这是最简单的配置多用户方式。方法是编辑 /etc/v2ray/config.json 文件,在”clients“一节中增加新增用户配置。例如在上面配置基础上增加一个用户:
{
"log": {
"loglevel": "info",
"access": "/var/log/v2ray/access.log",
"error": "/var/log/v2ray/error.log"
},
"inbounds": [{
"port": 12345,
"protocol": "vmess",
"settings": {
"clients": [
{
"id": "6be0aa25-09c1-4d8b-a96f-75cd3485021f",
"level": 1,
"alterId": 53
}, # 逗号不能少
# 下面是新增的内容
{
"id": "2a1292fd-07be-37e7-af20-57668b4a546a", # id可以用 /usr/bin/v2ray/v2ctl uuid生成
"level": 1, # 这个不用改
"alterId": 63 # 建议50-150之间的一个整数
}
# 新增内容结束
]
}
}],
# 下面的内容保持不变
注意:“#”和后面的东西都不能出现在配置文件中,上面只是为了解释说明。
编辑好文件后,重启 v2ray:systemctl restart v2ray
。如果命令失败,或者 netstat -nltp | grep v2ray
输出为空,说明配置文件有错误,请仔细检查,改好后再重启。接下来就可以用新的id和alterId配置客户端,其余信息保持不变。
如果希望端口也不一样,请按照如下步骤做:
首先编辑 /etc/v2ray/config.json
文件,按照”inbounds“格式新增入口和用户。例如新增一个端口和用户后,配置文件变成:
{
"log": {
"loglevel": "info",
"access": "/var/log/v2ray/access.log",
"error": "/var/log/v2ray/error.log"
},
"inbounds": [{
"port": 12345,
"protocol": "vmess",
"settings": {
"clients": [
{
"id": "6be0aa25-09c1-4d8b-a96f-75cd3485021f",
"level": 1,
"alterId": 53
}
]
}
}, # 逗号不能省,原来这里是"}],"
# 以下是新增的配置
{
"port": 54321, # 端口是1000-65535之间的一个整数
"protocol": "vmess", # 也可以改成其他协议,如果你知道怎么配置的话
"settings": {
"clients": [
{
"id": "24813255-228d-b0e0-c3fa-e5d4c9defda1", # id可以用 /usr/bin/v2ray/v2ctl uuid生成
"level": 1, # 0或1都可以
"alterId": 57 # 建议50-150之间的一个整数
}
]
}
}],
# 新增内容结束
# 下面的内容保持不变
注意:“#”和后面的东西都不能出现在配置文件中,上面只是为了解释说明。
设置防火墙放行新增的端口。CentOS系统命令是:
firewall-cmd --permanent --add-port=54321/tcp # 注意:54321要改成你的端口号
firewall-cmd --permanent --add-port=54321/udp # 注意:54321要改成你的端口号
firewall-cmd --reload
Ubuntu系统命令是:
ufw allow 54321/tcp # 注意:54321要改成你的端口
ufw allow 54321/udp # 注意:54321要改成你的端口
接下来用新的端口、id和alterId配置客户端,其余信息保持不变。
同端口不同id的配置和普通版操作方法一样,配置好后重启v2ray就行了,这里不再重复。
接下来说说不同端口不同id的情形。伪装有了Nginx的介入,所以有多种情况,这里只介绍最简单的一种实现方式。
编辑 /etc/v2ray/config.json 文件,按照 普通版同端口不同id 中的方法添加用户;
编辑 /etc/nginx/conf.d/你的域名.conf 文件,找到 “listen 443 ssl http2;” 这一行,在这行下面添加“listen 新的端口号 ssl http2;”一行(新的端口号要改成整数,例如8443,不能是443)。然后保存文件, nginx -t 检查配置有没有错误,没有错误的话重启Nginx:systemctl restart nginx
;
设置防火墙放行端口,请参考 普通版设置防火墙 中的命令。
接下来用新的端口、id和alterId配置客户端,其余信息保持不变。如果你想添加多个端口或多个用户,重复上面的过程就可以了。
编辑好文件后,重启 v2ray:
systemctl restart v2ray
如果命令失败,或者 netstat -nltp | grep v2ray
输出为空,说明配置文件有错误,请仔细检查,改好后再重启。
查看v2ray运行状态 / 配置:bash <(curl -sL https://raw.githubusercontent.com/hijkpw/scripts/master/centos_install_v2ray2.sh) info
v2ray管理命令:启动:systemctl start v2ray
,停止:systemctl stop v2ray
,重启:systemctl restart v2ray
;
nginx管理命令:测试配置文件有无错误:nginx -t
,启动:systemctl start nginx
,停止:systemct stop nginx
,重启:systemctl restart nginx
;
更新v2ray到最新版:bash <(curl -L -s https://install.direct/go.sh)
查看SSL证书:certbot certificates
,更新证书:systemctl stop nginx; certbot renew; systemctl restart nginx
卸载: bash <(curl -sL https://raw.githubusercontent.com/hijkpw/scripts/master/centos_install_v2ray2.sh) uninstall
;
建站/改伪装网站请参考:v2ray伪装建站教程。
2020.8.1 Hexo 5.0后要将主题配置文件复制到站点根目录,然后重命名为 _config.next.yml
通常情况下请选择 stable 版本。推荐不熟悉的用户按此方式进行。
这种方式将仅提供最新的 release 版本(其中不附带 .git
目录)。因此,你无法通过 git 更新这一方式安装的主题。
更新:推荐使用独立的配置文件(数据文件)而不在主题源代码进行更改,便于后续的更新(下载最新版本,替换掉旧版本)。
我们在站点的配置文件_config.yml
中找到 theme 后修改:
theme: next # 配置成刚下载的next主题
# Site
title: # 网站标题
subtitle: # 网站副标题
description: # 描述,介绍网站的
keywords: # 网站的关键字
author: # 博主姓名
language: zh-CN # 语言:zh-CN 是简体中文
timezone: UTC # 时区
本着简单原则,在站点配置文_config.yml
件里将固定链接改成:
url: https://bore.vip
root: /
permalink: archives/:title/
减少出站链接能够有效防止权重分散,hexo 有很方便的自动为出站链接添加 nofollow
标签的插件。
首先安装 hexo-filter-nofollow
插件:
npm install hexo-filter-nofollow --save
然后我们在站点的配置文件_config.yml
中添加配置,将 nofollow
设置为 true
:
# 外部链接优化
nofollow:
enable: true
field: site
exclude:
- 'exclude1.com'
- 'exclude2.com'
其中 exclude
(例外的链接,比如友链)将不会被加上 nofollow
属性。
npm install hexo-generator-sitemap --save
然后我们需要在 Hexo 站点配置文件中加入 sitemap 插件:
# 通用站点地图
sitemap:
path: sitemap.xml
把图标放在 /themes/next/source/images 里,并且修改 主题配置文件(next.yml):
favicon:
small: /images/favicon-16x16-next.png
medium: /images/favicon-32x32-next.png
apple_touch_icon: /images/favicon-32x32-next.png
safari_pinned_tab: /images/favicon-32x32-next.png
#android_manifest: /images/manifest.json
#ms_browserconfig: /images/browserconfig.xml
Next主题在7.3之后分离了配置文件与主题,详情请见小丁的个人博客
新建文件夹hexo/source/_data
将./themes/next/_config.yml
复制到hexo/source/_data
路径下并重命名为next.yml
将next.yml
中的override
设置为true
即可作为主题的配置文件使用
override: true
在hexo/source/_data
中新建body-end.swig
和styles.styl
文件
然后在next.yml
的custom_file_path
中删除前面的#
来启用bodyEnd
和style
custom_file_path
中的其他选项根据需要创建相关文件并启用
主题配置文件(next.yml),关键字:Schemes
,修改
#scheme: Muse
#scheme: Mist
#scheme: Pisces #打开前面的注释
scheme: Gemini
Muse - 默认 Scheme,这是 NexT 最初的版本,黑白主调,大量留白
Mist - Muse 的紧凑版本,整洁有序的单栏外观
Pisces - 双栏 Scheme,小家碧玉似的清新
Gemini - 左侧网站信息及目录,块+片段结构布局
默认的主题配置文件_config.yml
(next.yml) 中,菜单只开启了首页和归档,我们根据需要,可以添加 about、tag、categories、sitemap 等菜单,所以把它们也取消注释。
# 菜单设置为 菜单名: /菜单目录 || 菜单图标名字
menu:
home: / || home
about: /about/ || user
tags: /tags/ || tags
categories: /categories/ || th
archives: /archives/ || archive
#schedule: /schedule/ || calendar
sitemap: /sitemap.xml || sitemap
commonweal: /404/ || heartbeat
menu_settings:
icons: true # 显示图标
badges: true # 显示统计信息
注:hexo 所有图标均来自 fontawesome,其中 ||
后面是你想要设置的图标的名字。
菜单项的中文文本翻译见菜单中文翻译
我们可以在博客根目录下输入以下命令新建页面:
hexo new page about
然后你会发现多了一个 hexo/source/about 文件夹,里面有一个 index.md 文件,你可以根据自己的需要在这个 Markdown 文件中写一些内容(同文章一样,用 Markdown 语法)。
同样的,我们可以新建 tags
页面:
hexo new page tags
在 tags
页面文件 hexo/source/tags/index.md
的头部修改为:
---
title: 标签
date: 2020-04-26 00:13:30 # 时间随意
type: "tags" # 类型一定要为tags
comments: false # 提示这个页面不需要加载评论
---
同样的,我们可以新建 categories 页面:
hexo new page categories
在 categories 页面文件 hexo/source/categories/index.md 的头部修改为:
---
title: 文章分类
date: 2020-04-26 00:15:00
type: "categories"
comments: false
---
这里我们将 404 替换成腾讯的公益页面。
首先我们在 hexo/source
目录下创建自己的 404.html
:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>404</title>
</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>
注意:Hexo 博客的基本内容是一些 Markdown 文件,放在 source/_post 文件夹下,每个文件对应一篇文章。除此之外,放在 source 文件夹下的所有开头不是下划线的文件,在 hexo generate 的时候,都会被拷贝到 public 文件夹下。但是,Hexo 默认会渲染所有的 HTML 和 Markdown 文件。
因此我们可以简单地在文件开头加上 layout: false 一行来避免渲染:
layout: false
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>404</title>
</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>
这样我们就完成了 404 页面的创建。注意:本地测试不出来,发布出来就### 配置 hexo 本地搜索可以了。
对于动态网站来说,可以通过 php 实现。但是,Hexo 博客是静态网站,用不了 php。 NexT 主题已经实现这个功能,它用了 Hexo 的拓展包 hexo-generator-searchdb,预先生成了一个文本库 search.xml,然后传到了网站里面。在本地搜索的时候,NexT 直接用 javascript 调用了这个文件,从而实现了静态网站的本地搜索。
安装插件:
npm install hexo-generator-searchdb --save
然后我们修改站点配置_config.yml 文件,添加如下内容:
# 本地搜索
search:
path: search.xml
field: all
format: html
limit: 100
path:索引文件的路径,相对于站点根目录
field:搜索范围,默认是 post,还可以选择 page、all,设置成 all 表示搜索所有页面
limit:限制搜索的条目数
然后修改主题配置文件_config.yml
(next.yml):
# Local Search
# Dependencies: https://github.com/theme-next/hexo-generator-searchdb
local_search:
enable: true
# If auto, trigger search by changing input.
# If manual, trigger search by pressing enter key or search button.
trigger: auto
# Show top n results per article, show all results by setting to -1
top_n_per_article: 1
# Unescape html strings to the readable one.
unescape: false
# Preload the search data when the page loads.
preload: false
注意右上角选择国际版。
你可以点击 LeanCloud ,注册登录,进入控制台后点击创建应用。
进入刚刚创建的应用,选择设置 》应用Keys,就能看到你的 APP ID 和 APP Key
注意guest_info
这一栏,删除link,评论框就没有网址选项。
# Valine
# You can get your appid and appkey from https://leancloud.cn
# For more information: https://valine.js.org, https://github.com/xCss/Valine
# 配置项详情请查阅官方文档。
valine:
enable: true # 开启评论功能
appid: # 填入刚刚获取的APP ID
appkey: # 填入刚刚获取的APP key
notify: false # 邮件通知默认关闭
verify: false # 验证码默认关闭
placeholder: 在这里写下你的评论吧! # 评论框默认文字
avatar: mm # 头像风格
guest_info: nick,mail #,link # Custom comment header
pageSize: 10 # Pagination size
language: # Language, available values: en, zh-cn
visitor: false # leancloud-counter-security is not supported for now. When visitor is set to be true, appid and appkey are recommended to be the same as leancloud_visitors' for counter compatibility. Article reading statistic https://valine.js.org/visitor.html
comment_count: false # If false, comment count will only be displayed in post page, not in home page
recordIP: false # 是否记录IP
serverURLs: # 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
打开themes -> next -> languages -> zh-CN.yml
# 在post标签下添加如下代码 comments: valine: 评论数 # 这里的中文随便自己定义
没有用,不推荐
底部 footer
可以开关显示 hexo 信息、theme 信息、建站时间等个性化配置:
footer:
since: 2020 # 建站开始时间
icon:
name: user # 设置 建站初始时间和至今时间中间的图标,默认是一个'小人像',更改user为heart可以变成一个心
animated: true
color: "#808080" # 更改图标的颜色,红色为'#ff0000'
powered:
enable: true # 开启hexo驱动
version: true # 开启hexo版本号
theme:
enable: true # 开启主题驱动
version: true # 开启主题版本号
custom_text: Hosted by <a target="_blank" rel="external nofollow" href="https://pages.coding.me"><b>Coding Pages</b></a> # 这里的底部标识是为了添加coding page服务时的版权声明 打开注释就可以看到底部有一个 hosted by coding pages
avatar:
url: /images/avatar.jpg # 设置头像资源的位置
rounded: true # 开启圆形头像
opacity: 1 # 不透明的比例:0就是完全透明
rotated: false # 不开启旋转
这里和菜单设置格式一样,社交名字: 社交url || 社交图标,图标信息来自 fontawesome:
social:
GitHub: https://github.com/yourname || github
E-Mail: mailto:yourname@gmail.com || envelope
Google: https://plus.google.com/yourname || google
social_icons:
enable: true # 显示社交图标
icons_only: false # 只显示图标,不显示文字
友链配置:
# Blog rolls
links_icon: link # 友链的图标 参考上文
links_title: Links # 友链的title 比如你可以更改为 友情链接
links_layout: block # 友链摆放的样式:按块(一行一个)
#links_layout: inline # 友链摆放的样式:按线摆放(一行很多个),注意,同时只能一种样式
links:
Title: http://example.com/ # 友链的地址
官方提供的友链放在侧边栏下面,视觉上比较臃肿。这里我新建了一个友链页面:友情链接,设置教程见:Hexo-NexT 新增友链。
官方公告:
auto_excerpt
可以自动截断文章内容作为摘要。此功能不是一个 Hexo 主题应当负责的,这为主题的维护者带来了太大压力。自 7.6.0 版本开始,此功能被移除,请自行安装第三方插件,或阅读 Hexo 有关文档。当然,我们仍然建议通过 `` 来精确控制 Read More 的位置。
因此,这个功能在新版的 NexT 已经被废弃了,大家可以直接在文章中添加 <!-- more --> 来精确控制摘要内容。
post_meta:
item_text: false # 设为true 可以一行显示,文章的所有属性
created_at: true # 显示创建时间
updated_at:
enabled: true # 显示修改的时间
another_day: true # 设true时,如果创建时间和修改时间一样则显示一个时间
categories: true # 显示分类信息
busuanzi_count:
enable: false # 设true 开启
total_visitors: true # 总阅读人数(uv数)
total_visitors_icon: user # 阅读总人数的图标
total_views: true # 总阅读次数(pv数)
total_views_icon: eye # 阅读总次数的图标
post_views: true # 开启内容阅读次数
post_views_icon: eye # 内容页阅读数的图标
首先安装插件:
npm install hexo-symbols-count-time --save
主题配置文件_config.yml(next.yml) 修改如下:
symbols_count_time:
separated_meta: true # false会显示一行
item_text_post: true # 显示属性名称,设为false后只显示图标和统计数字,不显示属性的文字
item_text_total: true # 底部footer是否显示字数统计属性文字
awl: 4 # 计算字数的一个设置,没设置过
wpm: 275 # 一分钟阅读的字数
站点配置文件_config.yml 新增如下:
symbols_count_time:
#文章内是否显示
symbols: true
time: true
# 网页底部是否显示
total_symbols: true
total_time: true
codeblock:
copy_button:
enable: false # 增加复制按钮的开关
show_result: true # 点击复制完后是否显示 复制成功 结果提示
hexo\source_data\next.yml里修改:
codeblock:
# Code Highlight theme
# See: https://github.com/highlightjs/highlight.js/tree/master/src/styles
theme:
light: agate
dark: dark
# See: https://github.com/PrismJS/prism/tree/master/themes
prism:
light: prism
dark: prism-dark
# Add copy button on codeblock
copy_button:
enable: true
# Available values: default | flat | mac
style: mac
# Reward
reward_comment: # 打赏描述
wechatpay: /images/wechatpay.png # 微信支付的二维码图片地址
alipay: /images/alipay.png # 支付宝的地址
#bitcoin: /images/bitcoin.png # 比特币地址
安装推荐文章的插件:
npm install hexo-related-popular-posts --save
主题配置信息(next.yml)如下:
related_posts:
enable: true
title: 相关文章推荐 # 属性的命名
display_in_home: false # false代表首页不显示
params:
maxCount: 5 # 最多5条
#PPMixingRate: 0.0 # 相关度
#isDate: true # 是否显示日期
#isImage: false # 是否显示配图
isExcerpt: false # 是否显示摘要
creative_commons:
license: by-nc-sa
sidebar: false
post: true # 默认显示版权信息
language:
# Use icon instead of the symbol # to indicate the tag at the bottom of the post
# 标签代替#
tag_icon: true
back2top:
enable: false # 默认关闭
# Back to top in sidebar.
sidebar: true
# Scroll percent label in b2t button.
scrollpercent: true
npm install hexo-cake-moon-menu --save
If you are using NexT theme version 7.8 or earlier, install version 2.1.2
npm i hexo-cake-moon-menu@2.1.2
然后在站点配置文件`_config.yml 中添加以下代码:
moon_menu:
back2top:
enable: true
icon: fa fa-chevron-up
func: back2top
order: -1
back2bottom:
enable: true
icon: fa fa-chevron-down
func: back2bottom
order: -2
scheme选择Gemini
menu_settings:
badges: true # 显示菜单分类的数目
修改hexo\scaffolds\post.md
title: {{ title }} date: {{ date }} categories: [] tags: [] abbrlink: top:
首先在 hexo/scripts
下新建一个 newpost.js
文件,如果没有 scripts
文件可以手动创建一个。
在这个文件写入如下代码:
var spawn = require('child_process').exec;
hexo.on('new', function(data){
spawn('start "markdown编辑器绝对路径.exe" ' + data.path);
});
注意里面要修改的是 Markdown 编辑器的绝对路径,我使用的是 Typora ,所以我的绝对路径是 D:\Program Files\Typora\Typora.exe
,大家可以对应进行修改。
Pjax是基于Ajax的插件,能实现网页局部无刷新载入,听起来很香,然而存在一些小问题:
使用Mediumzoom时,从归档进入博文不会加载图片,需要刷新网页才能加载
Echarts图表全部需要刷新才能显示,否则只有一片空白
安装Pjax,地址: next-theme /pjax ,运行以下代码安装:
git clone https://github.com/next-theme/pjax source/lib/pjax
然后在next.yml中搜索pjax并设置为pjax: true
如果部署是报错:
ERROR Process failed: lib/pjax/README.md YAMLException: end of the stream or a document separator is expected at line 9, column 102: ... languages` and other directories:
解决方法:安装完pjax插件后,部署时报错
在 Hexo 的 _config.yml 中找到名为 skip_render 的选项,然后设置为这样:
skip_render: - lib/**/*
显示当前网页的加载进度,安装:
git clone https://github.com/theme-next/theme-next-pace source/lib/pace
在next.yml中搜索Progress bar in the top during page loading并设置为
pace:
enable: true
# Reading progress bar
reading_progress:
enable: true
# Available values: top | bottom
position: top
color: "#37c6c0"
height: 3px
将背景图片放置在./hexo/themes/next/source/images中并命名为background.jpg 然后在./hexo/source/_data/styles.styl中添加
body {
background:url(/images/background.jpg);//图片路径
background-repeat: no-repeat;//是否重复平铺
background-attachment: fixed;//是否随着网页上下滚动而滚动,fixed为固定
background-position: 50% 50%;//图片位置
background-size: cover;//图片展示大小
-webkit-background-size: cover;
-o-background-size: cover;
-moz-background-size: cover;
-ms-background-size: cover;
opacity: 0.95;
footer > div > div {
color:#000000;//底部文字颜色
}
}
第二种代码:(未测试,目前使用的是上面的代码)
body {
background:url(/images/yourbackground.jpg);
background-repeat: no-repeat;
background-attachment:fixed; //不重复
background-size: cover; //填充
background-position:50% 50%;
}
//博客内容透明化
//文章内容的透明度设置
.content-wrap {
opacity: 0.95;
}
//侧边框的透明度设置
.sidebar {
opacity: 0.9;
}
//菜单栏的透明度设置
.header-inner {
background: rgba(255,255,255,0.9);
}
//搜索框(local-search)的透明度设置
.popup {
opacity: 0.9;
}
找到三种方法,在next7.7.2中都不起效。
# Schemes
#scheme: Muse
#scheme: Mist
#scheme: Pisces
scheme: Gemini
styles.styl
里添加代码方法一只有首页第一篇文章有阴影效果,其他两种方法都没有效果。(不折腾了)
.content-wrap {
background: initial;
}
.post-block {
box-shadow: 0 2px 6px 0 rgb(0,0,0,0.6), 0 0 6px 0 rgb(0,0,0,0.6)
background: #FFF
}
// 主页文章添加阴影效果
.post_block {
opacity: 0;
margin-top: 60px;
margin-bottom: 60px;
padding: 25px;
-webkit-box-shadow: 0 0 5px rgba(202, 203, 203, .5);
-moz-box-shadow: 0 0 5px rgba(202, 203, 204, .5);
}
// 主页文章添加阴影效果
.post {
margin-top: 0px;
margin-bottom: 60px;
padding: 25px;
-webkit-box-shadow: 0 0 5px rgba(202, 203, 203, .5);
-moz-box-shadow: 0 0 5px rgba(202, 203, 204, .5);
}
在./hexo/source/_data/styles.styl中添加
code {
color: #ff511A;
background: #fbf7f8;
margin: 2px;
}
diff
写法Next主题其实是自带代码块高亮显示的,但是有另外一种好玩的代码块高亮写法,叫 diff
语言。只需要在 markdown 语法代码块的语言选择处写上 diff
即可,然后在相应代码前面加上 -
和 +
就行了。
我们原来是通过配置主题下的 languages 目录中的 zh-CN.yml 文件来对菜单等进行中文翻译的,现在我们可以通过在 hexo/source/_data/ 下新建数据文件 languages.yml,配置如下:
zh-CN:
menu:
home: 首页
top: 热榜
archives: 归档
categories: 分类
tags: 标签
about: 关于
links: 友情链接
search: 搜索
schedule: 日程表
sitemap: 站点地图
commonweal: 公益 404
movies: 观影
books: 阅读
gallery: 画廊
reward:
donate: <i class="fa fa-qrcode fa-2x" style="line-height:35px;"></i>
wechatpay: 微信支付
alipay: 支付宝
bitcoin: 比特币
新建 source/_data/post-body-end.swig 文件,添加内容:
<div>
{% if not is_index %}
<div style="text-align:center;color: #ccc;font-size:14px;">-------------本文结束<i class="fa fa-paw"></i>感谢您的阅读-------------</div>
{% endif %}
</div>
在next.yml中,去掉注释
postBodyEnd: source/_data/post-body-end.swig
在自定义样式文件 hexo\source\_data\variables.styl
中添加:
// 圆角设置
$border-radius-inner = 20px 20px 20px 20px;
$border-radius = 20px;
然后在 NexT 的配置文件 next.yml 中取消 variables.styl 的注释:
variable: source/_data/variables.styl
在这里会有一个bug,左下角始终会有个白块。解决方法:你只需要在 source\_data\styles.styl
文件中添加一行代码即可:
:root{--body-bg-color: hsla(0,0%,100%,0)}
或者添加下列代码:
.sidebar {
box-shadow: none
background: none
}
首先修改主题配置文件 next.yml:
font:
- enable: false
+ enable: true
# Uri of fonts host. E.g. //fonts.googleapis.com (Default).
- host:
+ host: https://fonts.loli.net
# Font options:
# `external: true` will load this font family from `host` above.
# `family: Times New Roman`. Without any quotes.
# `size: xx`. Use `px` as unit.
# Global font settings used for all elements in <body>.
global:
external: true
- family:
+ family: Noto Serif SC
size:
修改配置文件 \hexo\source_data\variables.styl,增加如下代码:
// 中文字体
$font-family-monospace = consolas, Menlo, monospace, $font-family-base;
$font-family-monospace = get_font_family('codes'), consolas, Menlo, monospace, $font-family-base if get_font_family('codes');
之前版本:Hexo-NexT 添加打字特效、鼠标点击特效中,以下代码是放在 hexo/next/_layout/_custom/custom.swig
文件中的,现在这部分代码需要放到 hexo/source/_data/body-end.swig
文件中:
{# 鼠标点击特效 #}
{% if theme.cursor_effect == "fireworks" %}
<script async src="/js/cursor/fireworks.js"></script>
{% elseif theme.cursor_effect == "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 async src="/js/cursor/explosion.min.js"></script>
{% elseif theme.cursor_effect == "love" %}
<script async src="/js/cursor/love.min.js"></script>
{% elseif theme.cursor_effect == "text" %}
<script async src="/js/cursor/text.js"></script>
{% endif %}
{# 打字特效 #}
{% if theme.typing_effect %}
<script src="/js/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 %}
然后在 NexT 的配置文件 next.yml
中取消 body-end.swig
的注释:
bodyEnd: source/_data/body-end.swig
然后我们在 next.yml
中增加如下配置项:
# 鼠标点击特效
# mouse click effect: fireworks | explosion | love | text
cursor_effect: fireworks
# 打字特效
# typing effect
typing_effect:
colorful: true # 礼花特效
shake: false # 震动特效
注意:上面所有特效的 JS 代码文件都放在站点的 source 目录下(即 hexo/source/js/
)而不是主题目录下,如果没有 js 目录,则新建一个。
详见:Hexo-NexT 新增友链 从第一种友链方式改用第二种友链方式,因为第二种瀑布流友链样式是不用修改 NexT 主题源文件的。
参考:代码块折叠
现在我们把上面的代码放到 hexo/source/_data/sidebar.swig 文件中,并且做以下更改:
{% if theme.recent_posts %}
<div class="links-of-blogroll motion-element {{ "links-of-blogroll-" + theme.recent_posts_layout }}">
<div class="links-of-blogroll-title">
<!-- modify icon to fire by szw -->
<i class="fa fa-history fa-{{ theme.recent_posts_icon | lower }}" aria-hidden="true"></i>
{{ theme.recent_posts_title }}
</div>
<ul class="links-of-blogroll-list">
- {% set posts = site.posts.sort('-date') %}
+ {% set posts = site.posts.sort('-date').toArray() %}
{% for post in posts.slice('0', '5') %}
<li>
<a href="{{ url_for(post.path) }}" title="{{ post.title }}" target="_blank">{{ post.title }}</a>
</li>
{% endfor %}
</ul>
</div>
{% endif %}
这是因为 NexT 已经更换 Nunjucks 作为模板引擎。
然后在 NexT 的配置文件 next.yml 中取消 sidebar.swig 的注释:
sidebar: source/_data/sidebar.swig
最后,为了配置方便,在主题的next.yml
中添加了几个变量,如下:
recent_posts_title: 近期文章
recent_posts_layout: block
recent_posts: true
现在我们只需要把粒子时钟的 js 代码直接放入到 hexo/source/_data/sidebar.swig
文件即可。
详情见:Hexo-NexT 增加 canvas 粒子时钟
首先我们需要安装 hexo-generator-index-pin-top 这个插件,
npm uninstall hexo-generator-index --save npm install hexo-generator-index-pin-top --save
然后将以下代码放入 hexo/source/_data/post-meta.swig 文件
{% if post.top %} <span class="post-meta-divider">|</span> <i class="fa fa-thumb-tack"></i> <font color=7D26CD>置顶</font> <span class="post-meta-divider">|</span> {% endif %}
然后在 NexT 的配置文件 next.yml 中取消 post-meta.swig 的注释:
post-meta: source/_data/post-meta.swig
使用方法:在需要置顶的文章的 Front-matter 中加上 top: true 或者 top: 任意数字,比如:
--- title: TMDb电影数据分析 declare: true toc: true tags: - Python - 数据分析 categories: - 数据分析 - 实战 abbrlink: 7e380af2 date: 2018-11-23 13:20:03 top: 100 ---
注意:top 中数字越大,文章越靠前。
安装插件:
npm install hexo-neat --save
然后我们需要在站点配置文件中添加以下代码:
# 博文压缩
neat_enable: true
# 压缩html
neat_html:
enable: true
exclude:
# 压缩css
neat_css:
enable: true
exclude:
- '**/*.min.css'
# 压缩js
neat_js:
enable: false
mangle: true
output:
compress:
exclude:
- '**/*.min.js'
- '**/jquery.fancybox.pack.js'
- '**/index.js'
- '**/fireworks.js'
把 layout/archive.swig
改为 layout/index.swig
就行了。不过注意此时首页的 meta
信息是 archive
(归档)……要做个清爽合格的首页,可以把原 index.swig
的 meta
信息拷贝到新 index.swig
下。
// new index.swig (archive.swig)
- {% block title %}{{ __('title.archive') }} | {{ title }}{% endblock %}
+ {% block title %}{{ title }}{%- if theme.index_with_subtitle and subtitle %} - {{ subtitle }}{%- endif %}{% endblock %}
站点配置文件_config.yml
里修改:
index_generator:
path: ''
per_page: 10
order_by: -date
# Pagination
## Set per_page to 0 to disable pagination
per_page: 10
pagination_dir: page
关闭文章目录自动数字编号后,可以自定义目录数字编号。
在hexo\source_data\next.yml里修改:
toc:
enable: true
# Automatically add list number to toc.
number: false
# If true, all words will placed on next lines if header width longer then sidebar width.
wrap: false
# If true, all level of TOC in a post will be displayed, rather than the activated part of it.
expand_all: false
# Maximum heading depth of generated toc.
max_depth: 6
在根目录新建deploy.sh
,输入以下内容:
#!/bin/bash
echo -e "\033[0;32mDeploying updates to gitee...\033[0m"
git add .
git commit -m "site backup"
git push --force origin master
hexo clean
hexo g -d
有时候可能需要多次运行脚本才能提交成功,这时不妨手动输入命令。
图标库升级为 Font-Awesome 5 (theme-next/hexo-theme-next#1438)
模板格式从 swig
更改为 njk
菜单设置变更 (a527bfd)
-override: false
menu:
- home: / || fa fa-home
+ #home: / || fa fa-home
#about: /about/ || fa fa-user
#tags: /tags/ || fa fa-tags
#categories: /categories/ || fa fa-th
- archives: /archives/ || fa fa-archive
+ #archives: /archives/ || fa fa-archive
#schedule: /schedule/ || fa fa-calendar
#sitemap: /sitemap.xml || fa fa-sitemap
#commonweal: /404/ || fa fa-heartbeat
Valine 选项更新 (6e6fc74)
valine:
- appid: # Your leancloud application appid
- appkey: # Your leancloud application appkey
+ appId: # Your leancloud application appid
+ appKey: # Your leancloud application appkey
...
- guest_info: nick,mail,link # Custom comment header
+ meta: # Custom comment header
+ - nick
+ - mail
+ - link
codeblock:
...
- # Available values: normal | night | night eighties | night blue | night bright | solarized | solarized dark | galactic
- # See: https://github.com/chriskempson/tomorrow-theme
- highlight_theme: normal
+ # See: https://github.com/highlightjs/highlight.js/tree/master/src/styles
+ theme:
+ light: default
+ dark: dark
codeblock:
theme:
light: agate
dark: dark
# Add copy button on codeblock
copy_button:
enable: true
# Show text copy result.
show_result: true
# Available values: default | flat | mac
style: mac
你可以在这里预览代码高亮的效果:highlightjs 选择你喜欢的 style
即可。
custom_file_path:
#head: source/_data/head.njk
#header: source/_data/header.njk
#sidebar: source/_data/sidebar.njk
postMeta: source/_data/post-meta.njk
postBodyEnd: source/_data/post-body-end.njk
footer: source/_data/footer.njk
bodyEnd: source/_data/body-end.njk
variable: source/_data/variables.styl
#mixin: source/_data/mixins.styl
style: source/_data/styles.styl
同时将原 _data
目录下的 swig
文件后缀改为 njk
即可