前置教程:

最近在疯狂肝博客,主要方面在优化用户体验上,加功能加的比较少,

PS:很多js偷懒使用了jquery,请自行引入

CommentBarrage V3.0

2023.1.22更新:

原有对于Cloudbase的方法不可用,请移步:

最近新写了CommentBarrage,原来的bug比较多,干脆直接改成swiper了,这样用户可以自由切换,灵感来源于Eurkon,不过并没有去那里扒。

参考了这个文档:

PS:为了兼容butterfly-swiper,swiper使用的是v5.4.5,需要注意版本:

1
2
swiper_css: https://cdnjs.cloudflare.com/ajax/libs/Swiper/5.4.5/css/swiper.min.css
swiper_js: https://cdnjs.cloudflare.com/ajax/libs/Swiper/5.4.5/js/swiper.min.js

弹幕的配置请参照旧版:

commentBarrage.js参照以下进行修改:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
//commentBarrage v3.0 By Ariasaka
//for swiper and both(pjax or nopjax)
//ainb?!!!! qwq
/document.addEventListener('pjax:complete', startbarrage); //不用pjax请注释掉这一行
document.addEventListener('DOMContentLoaded', startbarrage);

function startbarrage(){
try{
clearInterval(timer);
document.querySelector('.comment-barrage').innerHTML="";
delete sw;
}catch(err){}
const commentBarrageConfig = {
//浅色模式和深色模式颜色,务必保持一致长度,前面是背景颜色,后面是字体,随机选择,默认这个颜色还好
lightColors:[
['var(--lyx-white-acrylic2)','var(--lyx-black)'],
],
darkColors:[
['var(--lyx-black-acrylic2)','var(--lyx-white)'],
],
//v3仅支持一个弹幕
//弹幕显示间隔时间,单位ms
barrageTime: 3000,
//twikoo部署地址(Vercel、私有部署),腾讯云的为环境ID
twikooUrl: "https://tkapi.yisous.xyz",
//token获取见前文
accessToken: "{YOUR_TOKEN}",
pageUrl: window.location.pathname,
barrageTimer: [],
barrageList: [],
barrageIndex: 0,
// 没有设置过头像时返回的默认头像,见cravatar文档 https://cravatar.cn/developers/api,可以不改以免出错
noAvatarType: "retro",
dom: document.querySelector('.comment-barrage'),
//是否默认显示留言弹幕
displayBarrage: true,
//头像cdn,默认cravatar
avatarCDN: "cravatar.cn",
}
function checkURL(URL){
var str=URL;
//判断URL地址的正则表达式为:http(s)?://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?
//下面的代码中应用了转义字符"\"输出一个字符"/"
var Expression=/http(s)?:\/\/([\w-]+\.)+[\w-]+(\/[\w- .\/?%&=]*)?/;
var objExp=new RegExp(Expression);
if(objExp.test(str)==true){
return true;
}else{
return false;
}
}
function isInViewPortOfOne (el) {
const viewPortHeight = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight
const offsetTop = el.offsetTop
const scrollTop = document.documentElement.scrollTop
const top = offsetTop - scrollTop
return top <= viewPortHeight
}
if(location.href.indexOf("posts")!=-1||location.href.indexOf("posts")!=-1)
document.onscroll = function() {
if(commentBarrageConfig.displayBarrage){
if(isInViewPortOfOne(document.getElementById("post-comment"))){
$(".comment-barrage").hide();
}
else{
$(".comment-barrage").show();
}
}
}
function initCommentBarrage(){

var data = JSON.stringify({
"event": "COMMENT_GET",
"commentBarrageConfig.accessToken": commentBarrageConfig.accessToken,
"url": commentBarrageConfig.pageUrl
});
var xhr = new XMLHttpRequest();
xhr.withCredentials = true;
xhr.addEventListener("readystatechange", function() {
if(this.readyState === 4) {
commentBarrageConfig.barrageList = commentLinkFilter(JSON.parse(this.responseText).data);
commentBarrageConfig.dom.innerHTML = '';
for(commentBarrageConfig.barrageIndex=0;commentBarrageConfig.barrageIndex<commentBarrageConfig.barrageList.length;commentBarrageConfig.barrageIndex++){
popCommentBarrage(commentBarrageConfig.barrageList[commentBarrageConfig.barrageIndex]);
}
kkksc03=new Swiper('.barrageswiper', {
direction: "vertical",
loop: true,
mousewheel:true,
autoplay: {
delay: commentBarrageConfig.barrageTime,
stopOnLastSlide: false,
disableOnInteraction: false,
},
})
kkksc03.el.onmouseover = function(){
kkksc03.autoplay.stop();
}
kkksc03.el.onmouseout = function(){
kkksc03.autoplay.start();
}
}
});
xhr.open("POST", commentBarrageConfig.twikooUrl);
xhr.setRequestHeader("Content-Type", "application/json");
xhr.send(data);
}
function commentLinkFilter(data){
data.sort((a,b)=>{
return a.created - b.created;
})
let newData = [];
data.forEach(item=>{
newData.push(...getCommentReplies(item));
});
return newData;
}
function getCommentReplies(item){
if(item.replies){
let replies = [item];
item.replies.forEach(item=>{
replies.push(...getCommentReplies(item));
})
return replies;
}else{
return [];
}
}
function popCommentBarrage(data){
let barrage = document.createElement('div');
let width = commentBarrageConfig.dom.clientWidth;
let height = commentBarrageConfig.dom.clientHeight;
barrage.className = 'comment-barrage-item'
let ran = Math.floor(Math.random()*commentBarrageConfig.lightColors.length)
document.getElementById("barragesColor").innerHTML=`[data-theme='light'] .comment-barrage-item { background-color:${commentBarrageConfig.lightColors[ran][0]};color:${commentBarrageConfig.lightColors[ran][1]}}[data-theme='dark'] .comment-barrage-item{ background-color:${commentBarrageConfig.darkColors[ran][0]};color:${commentBarrageConfig.darkColors[ran][1]}}`;
if(data.avatar!=undefined){
if(data.link!=undefined){
if(!checkURL(data.link)){
data.link="http://"+data.link;
}
barrage.innerHTML = `
<div class="barrageHead">
<img class="barrageAvatar" src="${data.avatar}"/>
<a href="${data.link}" class="barrageNick" target="_blank">${data.nick}</a>
<a href="javascript:switchCommentBarrage()" style="font-size:20px">×</a>
</div>
`
}
else{
barrage.innerHTML = `
<div class="barrageHead">
<img class="barrageAvatar" src="${data.avatar}"/>
<div class="barrageNick">${data.nick}</div>
<a href="javascript:switchCommentBarrage()" style="font-size:20px">×</a>
</div>
`
}
}
else{
if(data.link!=undefined){
if(!checkURL(data.link)){
data.link="http://"+data.link;
}
barrage.innerHTML = `
<div class="barrageHead">
<img class="barrageAvatar" src="https://${commentBarrageConfig.avatarCDN}/avatar/${data.mailMd5}?d=${commentBarrageConfig.noAvatarType}"/>
<a href="${data.link}" class="barrageNick" target="_blank">${data.nick}</a>
<a href="javascript:switchCommentBarrage()" style="font-size:20px">×</a>
</div>
`
}
else{
barrage.innerHTML = `
<div class="barrageHead">
<img class="barrageAvatar" src="https://${commentBarrageConfig.avatarCDN}/avatar/${data.mailMd5}?d=${commentBarrageConfig.noAvatarType}"/>
<div class="barrageNick">${data.nick}</div>
<a href="javascript:switchCommentBarrage()" style="font-size:20px">×</a>
</div>
`
}
}
barrageContent=document.createElement('a');
barrageContent.className="barrageContent";
barrageContent.href="#"+data.id;
barrageContent.innerHTML=data.comment;
barrage.appendChild(barrageContent);
aswiper = document.createElement('div');
aswiper.className="swiper-slide";
aswiper.setAttribute("style","height: 150px;");
aswiper.append(barrage);
commentBarrageConfig.dom.append(aswiper);
}
switchCommentBarrage = function () {
localStorage.setItem("isBarrageToggle",Number(!Number(localStorage.getItem("isBarrageToggle"))))
if(!isInViewPortOfOne(document.getElementById("post-comment"))){
commentBarrageConfig.displayBarrage=!(commentBarrageConfig.displayBarrage);
let commentBarrage = document.querySelector('.comment-barrage');
if (commentBarrage) {
$(commentBarrage).fadeToggle()
}
}

}
if(localStorage.getItem("isBarrageToggle")==undefined){
localStorage.setItem("isBarrageToggle","0");
}else if(localStorage.getItem("isBarrageToggle")=="1"){
localStorage.setItem("isBarrageToggle","0");
switchCommentBarrage()
}
initCommentBarrage()
}

commentBarrage.css:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/* .comment-barrage {

display: flex;
flex-direction: column;
justify-content: end;
align-items: flex-end;
} */
.barrageswiper{
position: fixed;
margin: 0 0 30px 10px;
z-index: 100;
bottom: 10px;
right: 55px;
}
@media screen and (max-width: 768px) {
.comment-barrage {
display: none;
}
}
.comment-barrage .swiper-slide{
position: relative;
width: 250px;
}
.comment-barrage-item {
position: absolute;
bottom: 5px;
width: 100%;
min-height: 80px;
max-height: 140px;
height: min-content;
margin: 4px 0;
padding: 8px;
background: rgba(0, 0, 0, 0.9);
backdrop-filter: blur(20px) saturate(180%);
border-radius: 8px;
color: #fff;
transition: 1s;
display: flex;
flex-direction: column;
border: 1px solid rgba(255, 255, 255, 0.2);
box-shadow: var(--heo-shadow-border);
}


.comment-barrage-item.out {
opacity: 0;
}

/* @keyframes barrageIn {
0% {
transform: translateY(20%);
-webkit-transform: translateY(20%);
-moz-transform: translateY(20%);
-ms-transform: translateY(20%);
-o-transform: translateY(20%);
opacity: 0;
}
100% {
transform: translateY(0%);
-webkit-transform: translateY(0%);
-moz-transform: translateY(0%);
-ms-transform: translateY(0%);
-o-transform: translateY(0%);
opacity: 1;
}
} */



.comment-barrage-item .barrageHead {
height: 30px;
padding: 0;
line-height: 30px;
font-size: 12px;
border-bottom: 1px solid rgba(255, 255, 255, 0.3);
display: flex;
justify-content: space-between;
align-items: center;
}

.comment-barrage-item .barrageAvatar {
width: 16px;
height: 16px;
margin: 0;
border-radius: 50%;
}

.comment-barrage-item .barrageContent {
font-size: 14px;
height: calc(100% - 30px);
overflow: scroll;
}

.comment-barrage-item .barrageContent::-webkit-scrollbar {
height: 0;
width: 4px;
}

.comment-barrage-item .barrageContent::-webkit-scrollbar-button {
display: none;
}
.barrageContent:not(.barrageContent:hover),.barrageNick:not(.barrageNick:hover){
color:var(--global-font-color)!important;
}
.barrageswiper{
height: 150px;
}
.comment-barrage-item p{
line-height: 1.2;

}

bbtalkLunboer

bbTalk已经停止维护且无官方的轮播插件,但是因为方便我还是在用,轮播我自己写了一个,之前的版本因为过于屎山与毒瘤并没有放出来,这次进行了pjax&swiper重构。

支持日期展示、自动链接替换(22.12.9 upd),目前依然有部分bug:

ps:因为部分内容过于远古,甚至是刚搞博客就有的,所以可能会有诸多bug,窝不负责 awa

22.12.16 upd:修复部分bug,更改显隐逻辑

跟上面同理,基于swiper5.4.5

请先自行引入leancloud-av:

1
<script src="https://gcore.jsdelivr.net/npm/leancloud-storage@4.13.4/dist/av-min.js"></script>

bbtalklunbo.js:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
//bbtalkLunboer v2.0 By Ariasaka
AV.init({
appId: "{YOUR_APPID}",
appKey: "{YOUR_APPKEY}",
serverURL: "{YOUR_URL}", //改成自己的,在设置->域名绑定
});
function lunbo(){
var speaks=[];
const query = new AV.Query('content');
Date.prototype.Format = function (fmt) {
var o = {
"M+": this.getMonth() + 1, //月份
"d+": this.getDate(), //日
"H+": this.getHours(), //小时
"m+": this.getMinutes(), //分
"s+": this.getSeconds(), //秒
"q+": Math.floor((this.getMonth() + 3) / 3), //季度
"S": this.getMilliseconds() //毫秒
};
if (/(y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
for (var k in o)
if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
return fmt;
}
query.find().then((talks) => {
dat=new Date()
for(i=talks.length;i>=talks.length-31;i--){
var usedTime = Date.parse(dat) - Date.parse(talks[i]["createdAt"]);
var days = Math.floor(usedTime / (24 * 3600 * 1000));
var leave1 = usedTime % (24 * 3600 * 1000);
var hours = Math.floor(leave1 / (3600 * 1000));
var leave2 = leave1 % (3600 * 1000);
var minutes = Math.floor(leave2 / (60 * 1000));
var bbcontent=talks[i]["attributes"]["content"].replace(/<[^>]+>/g, "").replace(/<[^>]+>/g, "").replace(/(?:http(s)?:\/\/)?[\w.-]+(?:\.[\w\.-]+)+[\w\-\._~:/?#[\]@!\$&'\*\+,;=.]+\.(png|jpg|jpeg|webp)/g,"[图片]").replace(/(?:http(s)?:\/\/)?[\w.-]+(?:\.[\w\.-]+)+[\w\-\._~:/?#[\]@!\$&'\*\+,;=.]+/g,"[链接]");
if(days>31){
speaks.push(String(talks[i]["createdAt"].Format("yyyy-MM-dd"))+":"+bbcontent)
}
else if(days>0){
speaks.push(String(days)+" 天前:"+bbcontent);
}
else if(hours>0){
speaks.push(String(hours)+" 小时前:"+bbcontent);
}
else{
speaks.push(String(minutes)+" 分钟前:"+bbcontent);
}
}
document.querySelector(".shuoshuo").innerHTML=""
for(i=1;i<speaks.length;i++){
var ch=document.createElement("div");
ch.className="swiper-slide bbtalks";
ch.innerHTML=speaks[i];
document.querySelector(".shuoshuo").appendChild(ch)
}
var fxxkccf = new Swiper("#speaks-content", {
loop: true,
direction: "vertical",
autoplay: {
delay: 5000,
disableOnInteraction: false, //暴戻语言 禁赛三年行为[doge]
},
mousewheel:true,
})
fxxkccf.el.onmouseover = function(){
fxxkccf.autoplay.stop();
}
fxxkccf.el.onmouseout = function(){
fxxkccf.autoplay.start();
}
});

}
document.addEventListener('pjax:complete', (e) => {
lunbo();
})
document.addEventListener('DOMContentLoaded', (e) => {
lunbo();
})

pug更改:

在一个合适的地方(因为我自己的比较特殊,建议在[blogRoot]\themes\acryple\layout\includes\mixins\post-ui.pug的第二行插入这句(注意缩进),编写:

1
include speaks.pug

同级目录新建speaks.pug:

1
2
3
4
5
a(id="speaks" class="recent-post-item swiper-container" style="width:100%;height:auto;padding:10px;display:flex;" href="/speaks/")         
i(class="fas fa-comment-alt" style="margin-top:10px")
#speaks-content
.shuoshuo.swiper-wrapper 博主说说
i(class="fa fa-arrow-right" style="margin-top:10px")

然后添加css:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
[data-theme='light'] #speaks{
color:var(--lyx-black);
font-size:18px;
border: 1px solid var(--lyx-border);
backdrop-filter: blur(30px) saturate(180%);
-webkit-backdrop-filter: blur(30px) saturate(180%);
background-color: var(--lyx-white-acrylic1)!important;
border-radius: 12px;
margin-top:20px;
margin-bottom: 10px;
}
[data-theme='dark'] #speaks{
color:var(--lyx-white);
font-size:18px;
border: 1px solid var(--lyx-border);
backdrop-filter: blur(30px) saturate(180%);
-webkit-backdrop-filter: blur(30px) saturate(180%);
border-radius: 12px;
background-color: var(--lyx-black-acrylic2)!important;
margin-top:20px;
margin-bottom:10px;
}
#speaks:hover{
border: 1px solid var(--lyx-theme);
box-shadow:0 0 3px var(--lyx-theme)!important;

}
#speaks i{
margin-right:10px;
margin-left:10px;
}
#speaks{
height: 56px!important;
}
.shuoshuo{
flex:1;
text-align: center;
}
.shuoshuo{
transition-property: background-color,color,padding,font-size,border;
transition-duration: 200ms;
}
.shuoshuo:hover{
color:var(--lyx-theme); /*换成自己的颜色*/
}
.shuoshuo{
white-space: nowrap;
}
#speaks-content{
max-width: 100%;
overflow: hidden;
}

适配pjax

真的真的是大工程!!!

参考:

Ariasaka Console v0.1


重构的博客设置,性能和ui美观度均有提高(目前仍有部分bug欢迎反馈)

注意与Leonus的切换背景有冲突。

新版博客设置进行了分区改造,把rightside全部转移到此,优化样式,性能优化,以及进行了前后端分离。

请先阅读这篇之前的文章来参考修改

功能:

  1. 自动主题切换
  2. 左右栏切换
  3. 把aside迁移了过来,请根据自己需求调整,并且隐藏默认aside
  4. 切换背景,参考Leonus
  5. 切换字体,其实这个很费流量和速度
  6. 切换主题,根据自己站的需求来加,可以删了
  7. 其它的个性化设置(落樱特效参考下面)
  8. 网站统计

(其中自动主题色和固定导航栏没写好)

新建[blogRoot]/themes\acryple\layout\includes\setting.pug

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
html
body
#settingWindow.js-pjax
span.setting-title
span#stt 控制面板
a(id="close-console" onclick="toggleWinbox();") ×
button#backer(onclick='$(\'.asetting\').hide();$(\'.settingx\').show();$(\'#backer\').hide()')
i.fa.fa-chevron-left
span 返回
.settings
#setting-buttons
button.settingx(onclick='$(\'#theme-settings\').show();$(\'.settingx\').hide();$(\'#backer\').show();')
i.fas.fa-layer-group
span 外观
button.settingx(onclick='$(\'#font-settings\').show();$(\'.settingx\').hide();$(\'#backer\').show();')
i.fa.fa-font
span 字体
button.settingx(onclick='$(\'#background-settings\').show();$(\'.settingx\').hide();$(\'#backer\').show();')
i.far.fa-image
span 背景
button.settingx(onclick='$(\'#con-echarts\').show();$(\'.settingx\').hide();$(\'#backer\').show();var evt = document.createEvent("HTMLEvents");evt.initEvent("resize", false, false);window.dispatchEvent(evt);')
i.fas.fa-chart-pie
span 统计
button.settingx(onclick='$(\'#con-abouts\').show();$(\'.settingx\').hide();$(\'#backer\').show();')
i.fa.fa-cloud-download
span 关于
#setting-hides
#theme-settings.asetting
h2.content-head 性能设置
p
.content(style='display:flex')
input#blur(type='checkbox', onclick='setBlur()')
.content-text 禁用模糊效果
//- .content(style='display:flex')
//- input#yjjs(type='checkbox', onclick='yjjs1()')
//- .content-text 硬件加速
.content(style='display:flex')
input#fpson(type='checkbox', onclick='fpssw()' style="flex-shrink: 0")
.content-text
span 开启帧率检测(
a(href='javascript:window.location.reload()') 刷新
span 后生效)
p
h2.content-head 主题设置
//- .content(style='display:flex')
//- input#hideAside(type='checkbox', onclick='toggleRightside()')
//- .content-text 隐藏侧边栏
.content(style='display:flex')
input#hideAplayer(type='checkbox', onclick='toggleAplayer()')
.content-text 显示aplayer
.content(style='display:flex')
input#hideSakura(type='checkbox', onclick='toggleSakuras()')
.content-text 落樱特效
.content(style='display:flex')
input#autoTheme(type='checkbox', onclick='toggleAutoTheme()')
.content-text 明暗模式自动切换
.content(style='display:flex')
input#autoColor(type='checkbox', onclick='autoColor()')
.content-text 自动主题色(跟随文章封面)
| 未完工
.content(style='display:flex')
input#hideAplayer(type='checkbox', onclick='toggleNav()')
.content-text 固定导航栏
| ###
.content(style='display:flex')
button.content-button(onclick='switchTheme()') 切换主题

p
h3.content-head 主题色
#themeColorSettings.content(style='display:flex')
input#red(type='radio', name='colors', onclick='setColor(\'red\')')
input#orange(type='radio', name='colors', onclick='setColor(\'orange\')')
input#yellow(type='radio', name='colors', onclick='setColor(\'yellow\')')
input#green(type='radio', name='colors', onclick='setColor(\'green\')')
input#blue(type='radio', name='colors', onclick='setColor(\'blue\')')
input#heoblue(type='radio', name='colors', onclick='setColor(\'heoblue\')')
input#darkblue(type='radio', name='colors', onclick='setColor(\'darkblue\')')
input#purple(type='radio', name='colors', onclick='setColor(\'purple\')')
input#pink(type='radio', name='colors', onclick='setColor(\'pink\')', checked)
input#black(type='radio', name='colors', onclick='setColor(\'black\')')
input#blackgray(type='radio', name='colors', onclick='setColor(\'blackgray\')')
#font-settings.asetting
h2.content-head 字体设置
p#swfs
a.swf(href='javascript:;', rel='noopener external nofollow', style='font-family:\'HYTMR\'!important;color:black', onclick='setFont(\'HYTMR\')') 汉仪唐美人
br
a.swf(href='javascript:;', rel='noopener external nofollow', style='font-family:\'HYPailou\'!important;color:black', onclick='setFont(\'HYPailou\')') 汉仪新蒂牌楼
br
a.swf(href='javascript:;', rel='noopener external nofollow', style='font-family:\'FZXJLJ\'!important;color:black', onclick='setFont(\'FZXJLJ\')') 方正金陵体
br
a.swf(href='javascript:;', rel='noopener external nofollow', style='font-family:\'FZXS\'!important;color:black', onclick='setFont(\'FZXS\')') 方正像素体
br
a.swf(href='javascript:;', rel='noopener external nofollow', style='font-family:\'ZhuZiAWan\'!important;color:black', onclick='setFont(\'ZhuZiAWan\')') 筑紫A丸ゴシック
br
a.swf(href='javascript:;', rel='noopener external nofollow', style='font-family:\'FZODZK\'!important;color:black', onclick='setFont(\'FZODZK\')') 方正欧蝶正楷
br
a.swf(href='javascript:;', rel='noopener external nofollow', style='font-family:\'Source Serif\'!important;color:black', onclick='setFont(\'Source Serif\')') 思源宋体
br
a.swf(href='javascript:;', rel='noopener external nofollow', style='font-family:\'Source Sans\'!important;color:black', onclick='setFont(\'Source Sans\')') 思源黑体
br
a.swf(href='javascript:;', rel='noopener external nofollow', style='font-family:-apple-system, IBM Plex Mono ,monosapce,\'微软雅黑\', sans-serif;', onclick='setFont(\'main\')') 系统默认
br
#background-settings.asetting
h2(style='margin-left:10px') 背景设置
div
span 注意:切换背景功能仅在Acrylic主题中生效,在Simple主题中无效
button.content-button(onclick='localStorage.removeItem(\'blogbg\');location.reload();')
i.fa-solid.fa-arrows-rotate
span 点我恢复默认背景
button.content-button(onclick='switchTheme()') 切换主题
h3 图片(手机)
.bgbox
a.pimgbox(href='javascript:;', rel='noopener external nofollow', style='background-image:url(https://bu.dusays.com/2022/08/30/630d6d4d539a5.webp)', onclick='changeBg(\'url(https://bu.dusays.com/2022/08/30/630d6d4d539a5.webp)\')')
a.pimgbox(href='javascript:;', rel='noopener external nofollow', style='background-image:url(https://bu.dusays.com/2022/08/30/630d6d4e15c9d.webp)', onclick='changeBg(\'url(https://bu.dusays.com/2022/08/30/630d6d4e15c9d.webp)\')')
a.pimgbox(href='javascript:;', rel='noopener external nofollow', style='background-image:url(https://bu.dusays.com/2022/08/30/630d6f22c03c6.webp)', onclick='changeBg(\'url(https://bu.dusays.com/2022/08/30/630d6f22c03c6.webp)\')')
a.pimgbox(href='javascript:;', rel='noopener external nofollow', style='background-image:url(https://bu.dusays.com/2022/08/30/630d6d56c83eb.webp)', onclick='changeBg(\'url(https://bu.dusays.com/2022/08/30/630d6d56c83eb.webp)\')')
a.pimgbox(href='javascript:;', rel='noopener external nofollow', style='background-image:url(https://bu.dusays.com/2022/08/30/630d6d50b439b.webp)', onclick='changeBg(\'url(https://bu.dusays.com/2022/08/30/630d6d50b439b.webp)\')')
h3 图片(电脑)
.bgbox
a.imgbox(href='javascript:;', rel='noopener external nofollow', style='background-image:url(https://bu.dusays.com/2022/08/30/630d6d5574d0e.webp)', onclick='changeBg(\'url(https://bu.dusays.com/2022/08/30/630d6d5574d0e.webp)\')')
a.imgbox(href='javascript:;', rel='noopener external nofollow', style='background-image:url(https://bu.dusays.com/2022/08/30/630d6d529adf9.webp)', onclick='changeBg(\'url(https://bu.dusays.com/2022/08/30/630d6d529adf9.webp)\')')
a.imgbox(href='javascript:;', rel='noopener external nofollow', style='background-image:url(https://bu.dusays.com/2022/08/30/630d6d5159b31.webp)', onclick='changeBg(\'url(https://bu.dusays.com/2022/08/30/630d6d5159b31.webp)\')')
a.imgbox(href='javascript:;', rel='noopener external nofollow', style='background-image:url(https://bu.dusays.com/2022/08/30/630d718bbeef6.webp)', onclick='changeBg(\'url(https://bu.dusays.com/2022/08/30/630d718bbeef6.webp)\')')
a.imgbox(href='javascript:;', rel='noopener external nofollow', style='background-image:url(https://bu.dusays.com/2022/08/30/630d72f237d19.jpg)', onclick='changeBg(\'url(https://bu.dusays.com/2022/08/30/630d72f237d19.jpg)\')')
a.imgbox(href='javascript:;', rel='noopener external nofollow', style='background-image:url(https://bu.dusays.com/2022/08/30/630d72f2032c8.jpg)', onclick='changeBg(\'url(https://bu.dusays.com/2022/08/30/630d72f2032c8.jpg)\')')
a.imgbox(href='javascript:;', rel='noopener external nofollow', style='background-image:url(https://bu.dusays.com/2021/12/01/7792ff0082ec4.jpg)', onclick='changeBg(\'url(https://bu.dusays.com/2021/12/01/7792ff0082ec4.jpg)\')')
a.imgbox(href='javascript:;', rel='noopener external nofollow', style='background-image:url(https://bu.dusays.com/2022/08/30/630d72ee6d4f3.png)', onclick='changeBg(\'url(https://bu.dusays.com/2022/08/30/630d72ee6d4f3.png)\')')
a.imgbox(href='javascript:;', rel='noopener external nofollow', style='background-image:url(https://bu.dusays.com/2022/08/30/630d72ed76532.jpg)', onclick='changeBg(\'url(https://bu.dusays.com/2022/08/30/630d72ed76532.jpg)\')')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://bu.dusays.com/2022/09/17/6324aea549be6.webp)\')')
img(src='https://bu.dusays.com/2022/09/17/6324aea549be6.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://bu.dusays.com/2022/09/17/6324aec701a68.webp)\')')
img(src='https://bu.dusays.com/2022/09/17/6324aec701a68.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://bu.dusays.com/2022/09/17/6324aef4a5543.webp)\')')
img(src='https://bu.dusays.com/2022/09/17/6324aef4a5543.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://bu.dusays.com/2022/09/17/6324af3622884.webp)\')')
img(src='https://bu.dusays.com/2022/09/17/6324af3622884.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/5.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/5.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/6.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/6.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/7.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/7.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://bu.dusays.com/2022/12/08/6391b77ed767c.png)\')')
img(src='https://bu.dusays.com/2022/12/08/6391b77ed767c.png')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/9.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/9.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/10.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/10.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/11.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/11.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/12.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/12.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/13.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/13.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/14.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/14.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/15.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/15.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/16.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/16.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/17.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/17.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/18.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/18.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/19.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/19.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/20.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/20.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/21.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/21.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/22.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/22.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/23.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/23.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/24.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/24.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/25.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/25.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/26.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/26.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/27.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/27.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/28.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/28.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/29.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/29.webp')
a.imgbox(href='javascript:;', onclick='changeBg(\'url(https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/30.webp)\')')
img(src='https://cdn.afdelivr.top/npm/saiodgm-api@1.0.1/randomimg-my/30.webp')
h3 渐变色
.bgbox
a.box(href='javascript:;', rel='noopener external nofollow', style='background: linear-gradient(to right, #eecda3, #ef629f)', onclick='changeBg(\'linear-gradient(to right, #eecda3, #ef629f)\')')
a.box(href='javascript:;', rel='noopener external nofollow', style='background: linear-gradient(to right, #B7D31E, #42CE1E)', onclick='changeBg(\'linear-gradient(to right, #B7D31E, #42CE1E)\')')
a.box(href='javascript:;', rel='noopener external nofollow', style='background: linear-gradient(to right, #06DE86, #06A5DE)', onclick='changeBg(\'linear-gradient(to right, #06DE86, #06A5DE)\')')
a.box(href='javascript:;', rel='noopener external nofollow', style='background: linear-gradient(to right, #189BC4, #183DC4)', onclick='changeBg(\'linear-gradient(to right, #189BC4, #183DC4)\')')
a.box(href='javascript:;', rel='noopener external nofollow', style='background: linear-gradient(to right, #C018C4, #C41818)', onclick='changeBg(\'linear-gradient(to right, #C018C4, #C41818)\')')
a.box(href='javascript:;', rel='noopener external nofollow', style='background: linear-gradient(to right, #8B00BB, #030094)', onclick='changeBg(\'linear-gradient(to right, #8B00BB, #030094)\')')
a.box(href='javascript:;', rel='noopener external nofollow', style='background: linear-gradient(to right, #eecda3, #ef629f)', onclick='changeBg(\'linear-gradient(to right, #eecda3, #ef629f)\')')
a.box(href='javascript:;', rel='noopener external nofollow', style='background: linear-gradient(90deg, #ffd7e4 0%, #c8f1ff 100%)', onclick='changeBg(\'linear-gradient(90deg, #ffd7e4 0%, #c8f1ff 100%)\')')
a.box(href='javascript:;', rel='noopener external nofollow', style='background: linear-gradient(45deg, #e5737b, #c6999e, #96b9c2, #00d6e8)', onclick='changeBg(\'linear-gradient(45deg, #e5737b, #c6999e, #96b9c2, #00d6e8)\')')
h3 纯色
.bgbox
a.box(href='javascript:;', rel='noopener external nofollow', style='background: #7D9D9C', onclick='changeBg(\'#7D9D9C\')')
a.box(href='javascript:;', rel='noopener external nofollow', style='background: #fff', onclick='changeBg(\'#fff\')')
a.box(href='javascript:;', rel='noopener external nofollow', style='background: #49A6E9', onclick='changeBg(\'#49A6E9\')')
a.box(href='javascript:;', rel='noopener external nofollow', style='background: #F7CEFF', onclick='changeBg(\'#F7CEFF\')')
a.box(href='javascript:;', rel='noopener external nofollow', style='background: #FFFFCE', onclick='changeBg(\'#FFFFCE\')')
a.box(href='javascript:;', rel='noopener external nofollow', style='background: #CFFFCE', onclick='changeBg(\'#CFFFCE\')')
a.box(href='javascript:;', rel='noopener external nofollow', style='background: #17EFE9', onclick='changeBg(\'#17EFE9\')')
a.box(href='javascript:;', rel='noopener external nofollow', style='background: #9F17EF', onclick='changeBg(\'#9F17EF\')')
#con-echarts.asetting
h1 文章统计
h2 监控
iframe(src="https://status.yisous.xyz" width="100%" height="500px" frameborder="no")
if !is_page()
h2 文章统计
script(src="https://npm.elemecdn.com/echarts@4.9.0/dist/echarts.min.js")
div(id="posts-chart" data-start="2021-01" style="border-radius: 8px; height: 300px; padding: 10px;")
div(id="tags-chart" data-length="10" style="border-radius: 8px; height: 300px; padding: 10px;")
div(id="categories-chart" data-parent="true" style="border-radius: 8px; height: 300px; padding: 10px;")
h2 访问统计
| 显示不出来请刷新页面
//-下面换成自己的51la统计

#con-abouts.asetting
h1 关于
| Hexo-theme-Acryple v1.1.4
br
| Ariasaka Console v1.0
br
| 欢迎
a(href="/messageboard")
| 反馈!
#setting-sidesl
button(title="恢复默认设置" class="reSettings con-rightside")
i.fa.fa-repeat
#setting-sides
button(title="繁简转换" class="con-rightside" id="con-translate" onclick="javascript:rmf.translate();")
i.iconfont.icon-fanti
button(title="昼夜切换" class="con-rightside" id="con-mode" onclick="switchDarkMode();")
i.fa.fa-adjust
if is_post()||is_page()
button(title="阅读模式" class="con-rightside" id="con-reading" onclick="rmf.switchReadMode();")
i.fa.fa-book-open
if !is_page()
button(title="单双栏切换" class="con-rightside" id="con-toggleaside" onclick="toggleAside();")
i.fas.fa-arrows-alt-h
if !is_page()
button(title="左右栏切换" class="con-rightside" id="con-toggleleftaside" onclick="switchAside();")
i.fas.fa-binoculars
if is_post()||is_page()
button(title="开关弹幕" class="con-rightside" id="con-barrage" onclick="switchCommentBarrage();")
i.iconfont.icon-danmu
button(title="全屏" class="con-rightside" id="con-fullscreen" onclick="fullScreen();")
i.fas.fa-expand

js部分:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
document.addEventListener('pjax:complete', tosetting);
document.addEventListener('DOMContentLoaded', tosetting);
function tosetting(){
$("#settingWindow").hide();
if(localStorage.getItem("blur")=="false"){
blur=0;
}else{
blur=1;

}
if(localStorage.getItem("yjjs")=="true"){
yjjs=1;
}else{
yjjs=0;

}
if(localStorage.getItem("fpson")==undefined){
localStorage.setItem("fpson","1");
}
if(!blur){
document.getElementById("settingStyle").innerText=`
*,*:not(.card-info)::before,*::after{
-webkit-backdrop-filter: none!important;
backdrop-filter: none!important;
-webkit-filter: none!important;
filter: none!important;
}`}
else{
document.getElementById("settingStyle").innerText=''
}
setBlur=function(){
blur=!blur;
localStorage.setItem("blur",blur);
if(!blur){
document.getElementById("settingStyle").innerText=`
*{
-webkit-backdrop-filter: none!important;
backdrop-filter: none!important;
-webkit-filter: none!important;
filter: none!important;
}`}
else{
document.getElementById("settingStyle").innerText=''
}
}
// if(yjjs){
// document.getElementById("yjjs").innerText=`
// *:not(#web_bg){
// transform:translateZ(0);
// backface-visibility: hidden
// }`}
// else{
// document.getElementById("yjjs").innerText=``
// }
yjjs1=function(){
yjjs=!yjjs;
localStorage.setItem("yjjs",yjjs)
// if(yjjs){
// document.getElementById("yjjs").innerText=`
// *:not(#web_bg){
// transform:translateZ(0);
// backface-visibility: hidden
// }`}
// else{
// document.getElementById("yjjs").innerText=``
// }
}
if(localStorage.getItem("blogTheme")=="acrylic"){
document.getElementById("css").href="";
}
switchTheme=function(){
if(document.getElementById("css").href==window.location.protocol+"//"+window.location.host+"/css/stylessimple.css"){
document.getElementById("css").href=""
localStorage.setItem("blogTheme","acrylic");
}else{
document.getElementById("css").href="/css/stylessimple.css"
localStorage.setItem("blogTheme","simple");
}
}
setColor=function(c){
document.getElementById("themeColor").innerText=`:root{--lyx-theme:var(--lyx-${c})!important}`;
localStorage.setItem("themeColor",c);

}
setFont=function(n){
localStorage.setItem("font",n);
if(n=="main"){
var s=document.querySelectorAll("body,.aplayer")
for(var i = 0; i <s.length; i++) {
s[i].style.fontFamily="-apple-system, IBM Plex Mono ,monospace,'微软雅黑', sans-serif"
}
}
else if(n=="HYPailou"){
var s=document.querySelectorAll("body,.aplayer")
for(var i = 0; i <s.length; i++) {
s[i].style.fontFamily="Fredoka,HYPailou,KyoukashoProL,-apple-system, IBM Plex Mono ,monospace,'微软雅黑', sans-serif"
}
}
else{
var s=document.querySelectorAll("body,.aplayer")
for(var i = 0; i <s.length; i++) {
s[i].style.fontFamily="var(--global-font),KyoukashoProL,-apple-system, IBM Plex Mono ,monosapce,\"微软雅黑\", sans-serif"
}
document.body.style.fontFamily="var(--global-font),KyoukashoProL,-apple-system, IBM Plex Mono ,monosapce,'微软雅黑', sans-serif"
document.documentElement.style.setProperty('--global-font', n)
}
}
if(localStorage.getItem("themeColor")==undefined){
localStorage.setItem("themeColor","pink");
}

setColor(localStorage.getItem("themeColor"));



if(localStorage.getItem("hideRightside")==undefined){
localStorage.setItem("hideRightside","0");
}

if(localStorage.getItem("hideRightside")=="1"){
$("#rightside").toggle()
}
toggleRightside=function(){
$("#rightside").toggle();
localStorage.setItem("hideRightside",Math.abs(Number(localStorage.getItem("hideRightside"))-1))
}
if(localStorage.getItem("font")==undefined){
localStorage.setItem("font","HYTMR")
}
setFont(localStorage.getItem("font"))
// 存数据
// name:命名 data:数据
saveData=function(name, data) {
localStorage.setItem(name, JSON.stringify({ 'time': Date.now(), 'data': data }))
}

// 取数据
// name:命名 time:过期时长,单位分钟,如传入30,即加载数据时如果超出30分钟返回0,否则返回数据
loadData=function(name, time) {
let d = JSON.parse(localStorage.getItem(name));
// 过期或有错误返回 0 否则返回数据
if (d) {
let t = Date.now() - d.time
if (t < (time * 60 * 1000) && t > -1) return d.data;
}
return 0;
}
// 切换背景函数
// 此处的flag是为了每次读取时都重新存储一次,导致过期时间不稳定
// 如果flag为0则存储,即设置背景. 为1则不存储,即每次加载自动读取背景.
changeBg=function(s, flag) {
let bg = document.getElementById('web_bg')
if (s.charAt(0) == '#') {
bg.style.backgroundColor = s
bg.style.backgroundImage = 'none'
} else bg.style.backgroundImage = s
if (!flag) { saveData('blogbg', s) }
}
// 上面两个函数如果你有其他需要存取数据的功能,也可以直接使用

// 读取背景
try {
let data = loadData('blogbg', 1440)
if (data) changeBg(data, 1)
else localStorage.removeItem('blogbg');
} catch (error) { localStorage.removeItem('blogbg'); }



fpssw=function(){
if(localStorage.getItem("fpson")=="1"){
localStorage.setItem("fpson","0");
}else{
localStorage.setItem("fpson","1");
}
}
$(".asetting").hide();
$('#backer').hide();
$("#"+localStorage.getItem("themeColor")).attr("checked", true);
if(localStorage.getItem("blur")=="false"){
document.getElementById("blur").checked=true;
}
if(localStorage.getItem("yjjs")=="true"){
document.getElementById("yjjs").checked=true;
}
if(localStorage.getItem("fpson")=="1"){
document.getElementById("fpson").checked=true;
}


if(localStorage.getItem("sakurahide")=="false"){
document.getElementById("hideSakura").checked=true;
isSakura=1;
}
else if(localStorage.getItem("sakurahide")==null){
localStorage.setItem("sakurahide","false");
document.getElementById("hideSakura").checked=true;
isSakura=1;
}
else{
setTimeout(
stopp,1000);
isSakura=0;
}
if(localStorage.getItem("aplayerhide")=="false"){
document.getElementById("hideAplayer").checked=true;
}
else if(localStorage.getItem("aplayerhide")==null){
localStorage.setItem("aplayerhide","false");
document.getElementById("hideAplayer").checked=true;
}
else{
doStuff=function() {
flag=0;
try{
ap=aplayers[0];
ap.list;
flag=1;
}catch{
setTimeout(doStuff, 50);
return;
}
if(flag){
$(".aplayer-fixed").hide()
}
}
doStuff();

}

document.getElementsByClassName("reSettings")[0].onclick=function(){
localStorage.clear()
window.location.reload()
}

toggleWinbox=function(){
$("#settingWindow").fadeToggle();
if(document.getElementById("settingWindow").style.display!="none"){
document.getElementById("settingWindow").style.display="flex";
}
}
fullScreen=function() {
if (document.fullscreenElement) document.exitFullscreen()
else document.documentElement.requestFullscreen();
}
toggleAside=function(){
const $htmlDom = document.documentElement.classList
$htmlDom.contains('hide-aside')
? saveToLocal.set('aside-status', 'show', 2)
: saveToLocal.set('aside-status', 'hide', 2)
$htmlDom.toggle('hide-aside')
}
toggleAplayer=function(){
$(".aplayer-fixed").toggle()
if(localStorage.getItem("aplayerhide")=="true"){
localStorage.setItem("aplayerhide",false);
}
else{
localStorage.setItem("aplayerhide",true);
}
}
// position = $(window).scrollTop();
// $(window).scroll(function () {

// scroll = $(window).scrollTop();

// if (scroll > position) {
// document.getElementsByTagName("header")[0].style.transform="translateY(58px)";
// } else {


// document.getElementsByTagName("header")[0].style.transform="";

// }

// position = scroll;
// });
toggleSakuras=function(){
isSakura=!isSakura;
stopp(isSakura);
if(localStorage.getItem("sakurahide")=="true"){
localStorage.setItem("sakurahide",false);
}
else{
localStorage.setItem("sakurahide",true);
}
}
switchAside=function(){
if(left){
document.getElementById("aside-content").classList.add("right");
document.querySelector(".layout > div:first-child").classList.add("left");
localStorage.setItem("leftAside","false");
}
else{
document.getElementById("aside-content").className="aside-content";
document.querySelector(".layout > div:first-child").className="";
try{
document.querySelector("#recent-posts").className="recent-posts";
}catch(err){}localStorage.setItem("leftAside","true");}
left=!left;
}
left=1;
if(localStorage.getItem("leftAside")=="true"||localStorage.getItem("leftAside")==null){

}else{
switchAside();
}
if(localStorage.getItem("autoTheme")=="true"){
localStorage.setItem("autoTheme","false");
document.getElementById("autoTheme").checked=true;
var time=new Date();
if(time.getHours()<=7||time.getHours()>=19){
activateDarkMode()
saveToLocal.set('theme', 'dark', 2)
GLOBAL_CONFIG.Snackbar !== undefined && btf.snackbarShow(GLOBAL_CONFIG.Snackbar.day_to_night)
}
else{
activateLightMode()
saveToLocal.set('theme', 'light', 2)
GLOBAL_CONFIG.Snackbar !== undefined && btf.snackbarShow(GLOBAL_CONFIG.Snackbar.night_to_day)
}
}
if(location.href.indexOf('posts')!=-1){
var xhr = new XMLHttpRequest();
var url = document.querySelector('#page-header').style.backgroundImage.split('url("')[1].split('")')[0];
xhr.open("GET","https://apis.yisous.xyz/api/imageColor?imgurl="+url, true);
xhr.send();
xhr.onreadystatechange = function () {
if (xhr.readyState===4) {
if(xhr.status===200) {
document.getElementById("themeColor").innerText=`:root{--lyx-theme:${xhr.responseText}!important}`;
}
}
}
}
toggleAutoTheme=()=>{
if(localStorage.getItem("autoTheme")=="true"){
localStorage.setItem("autoTheme","false");
$("#con-mode").show();
}
else{
localStorage.setItem("autoTheme","true");
var time=new Date();
if(time.getHours()<=7||time.getHours()>=19){
activateDarkMode()
saveToLocal.set('theme', 'dark', 2)
GLOBAL_CONFIG.Snackbar !== undefined && btf.snackbarShow(GLOBAL_CONFIG.Snackbar.day_to_night)
}
else{
activateLightMode()
saveToLocal.set('theme', 'light', 2)
GLOBAL_CONFIG.Snackbar !== undefined && btf.snackbarShow(GLOBAL_CONFIG.Snackbar.night_to_day)
}
$("#con-mode").hide();
}
}
}
switchDarkMode = function () {
const nowMode = document.documentElement.getAttribute('data-theme') === 'dark' ? 'dark' : 'light'
if (nowMode === 'light') {
activateDarkMode()
saveToLocal.set('theme', 'dark', 2)
GLOBAL_CONFIG.Snackbar !== undefined && btf.snackbarShow(GLOBAL_CONFIG.Snackbar.day_to_night)
} else {
activateLightMode()
saveToLocal.set('theme', 'light', 2)
GLOBAL_CONFIG.Snackbar !== undefined && btf.snackbarShow(GLOBAL_CONFIG.Snackbar.night_to_day)
}
// handle some cases
typeof utterancesTheme === 'function' && utterancesTheme()
typeof FB === 'object' && window.loadFBComment()
window.DISQUS && document.getElementById('disqus_thread').children.length && setTimeout(() => window.disqusReset(), 200)
};

css:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
/*使用了Chrome105新特性has,兼容性不好qwq*/
.con-rightside{
height:50px!important;
width: 50px!important;
border-radius: 30px;
-webkit-border-radius: 30px;
-moz-border-radius: 30px;
-ms-border-radius: 30px;
-o-border-radius: 30px;
margin:10px;
transition: all .3s;
-webkit-transition: all .3s;
-moz-transition: all .3s;
-ms-transition: all .3s;
-o-transition: all .3s;
}
.con-rightside:hover{
background-color: rgba(129, 129, 129, 0.568);
}
.con-rightside i::before{
font-size:30px;
}
[data-theme="dark"] .con-rightside i::before{
color:white
}
.con-rightside:hover{
background-color: rgba(129, 129, 129, 0.568);
}
@media screen and (max-width:600px){
.con-rightside i::before{
font-size: 16px;
}
.con-rightside{
height:20px!important;
width:20px!important;
}
}
@media screen and (max-width:768px){
#con-barrage{
display: none!important;
}
}
#setting-buttons{
display: flex;
flex-wrap: wrap;
}
.setting-title{
text-align: center;
font-size: 30px;
display: flex;
}
#setting-sides{
margin-left: auto;
}
#setting-sides{
white-space: nowrap;
}
#setting-sidesl{
display: flex;
}
.settings .content{
margin-left:20px;
}
.settings{
margin:15px
}
/* 开关 */
.settings input[type="checkbox"] {
width: 38px;
height: 20px;
position: relative;
border: 1px solid #000000;
background-color: #0000;
border-radius: 12px;
background-clip: content-box;
display: inline-block;
-webkit-appearance: none;
user-select: none;
outline: none;
transform: translateY(5px);}
[data-theme="dark"] .settings input[type="checkbox"] {
border: 1px solid white;
}
.settings input[type="checkbox"]:before {
content: '';
width: 12px;
height: 12px;
position: absolute;
top: 3px;
left: 5px;
border-radius: 10px;
background-color: #000;}
[data-theme="dark"] .settings input[type="checkbox"]:before{
background-color: white;
}
.settings input[type="checkbox"]:checked {
background-color: var(--lyx-theme);border-color:var(--lyx-theme)}
.settings input[type="checkbox"]:checked:before {
left: 19px;background-color: white!important;}

.settings input[type="checkbox"] {
transition: border background-color box-shadow }
.settings input[type="checkbox"]:before {
transition: left 0.2s;}
.settings input[type="checkbox"]:checked {
background-color: var(--lyx-theme);
/* transition: border ease 0.4s, background-color ease 1.2s; */
}.settings input[type="checkbox"]:checked:before {
transition: left 0.2s;}
.settings input[type="checkbox"]:checked:hover{
opacity: 0.8;
}
.settings input[type="checkbox"]:active{
background-color: #666666!important;
border-color:#666666!important;
}
.settings input[type="checkbox"]:active::before{
background-color:white!important;
}
.settings{
overflow: scroll;
width: 100%;
}
#settingWindow{
position: fixed;
display: block;
width: 80%;
max-width: 800px;
left: 50%;
top: 50%;
max-height: 80%;
background-color: #ffffffdd;
border-radius: 20px;
-webkit-border-radius: 20px;
-moz-border-radius: 20px;
-ms-border-radius: 20px;
-o-border-radius: 20px;
border: 1px solid var(--lyx-border);
padding:30px;
backdrop-filter: blur(10px);
-ms-transform-origin-y:translate(-50%,-50%);
-webkit-transform:translate(-50%,-50%);
-moz-transform:translate(-50%,-50%);
-ms-transform:translate(-50%,-50%);
-o-transform:translate(-50%,-50%);
z-index: 514;
display: none;
}
.settings{
overflow: scroll;
width: 100%;
}
#settingWindow{
display: none;
flex-direction: column;
}
.settingx{
width: 46%;
text-align: left;
font-size: 28px;
padding: 10px;
margin: 10px;
background-color: var(--lyx-light-grey);
opacity: 0.8;
border-radius: 10px;
}
.settingx:hover{
background-color: var(--lyx-gray);
}
.settingx i{
margin: 5px;
}
@media screen and (max-width:768px){
.settingx{
width:100%!important;
}
}
.setting-title{
text-align: center;
font-size: 30px;
display: flex;
}
#close-console{
text-align: right;
}
#stt,#close-console{
margin-left: auto;
}
#close-console:not(#close-console:hover){
color: var(--global-font-color);
}

最后在[blogRoot]/themes/butterfly/layout/includes/layout.pug中添加:

1
2
3
4
...
include ./rightside.pug
!=partial('includes/third-party/search/index', {}, {cache: true})
+ !=partial('includes/setting',{}, {cache:false})

除此之外,还要引入一些外挂css标签,有些地方为了偷懒使用了jq,也需要加上:

1
2
3
4
5
6
7
8
9
inject:
head:
- <style id="settingStyle"></style>
- <style id="css"></style>
- <style id="themeColor"></style>
...
bottom:
- <script type="text/javascript" src="https://gcore.jsdelivr.net/npm/jquery@latest/dist/jquery.min.js"></script>
...

全站存储桶静态化

来由是看到Mrzefr的服务推荐,看到了缤纷云还不错,然后把字体扔上去。

突然想到个点子,这个存储桶是国内浙江节点,且不用备案,收费不贵,免费够用,因为之前的NPM全站静态化因为目前能用的cdn太少(静态文件超100M,jsd系全挂)而放弃,故有此野路子手法。

这样做其实不如直接套CDN,唯一的优势是享受国内速度,但是不用备案

请先充分阅读并彻底理解本文章:

上传网站

首先你需要想办法把网站传到存储桶上,你当然不会想着去手动更新,所以如果你使用Github actions上传的话,因为缤纷云这个存储桶兼容S3,直接使用AWS CLI即可。

不要看这么一点代码,可是翻遍全网资料才搞出来的,因为文档实在是太乱了。

在deploy的yml里面加入:

1
2
3
4
5
6
- name: Deploy static site to S3 bucket
run: |
export AWS_ACCESS_KEY_ID=${{ secrets.AWS_ACCESS_KEY_ID }}
export AWS_SECRET_ACCESS_KEY=${{ secrets.AWS_SECRET_ACCESS_KEY }}
export AWS_EC2_METADATA_DISABLED=true
aws s3 sync --endpoint-url https://s3.ladydaily.com ./public s3://${{ secrets.AWS_BUCKET_NAME }}

创建key

你首先需要创建一个key,

在控制台的AccessKey里面创建一个用户,生成Key并保管好(只显示一次!!!)

最后设置权限其实只用给写权限就行了。

设置secrets

给Actions加几个Secrets:

1
2
3
AWS_ACCESS_KEY_ID=你的Access Key
AWS_SECRET_ACCESS_KEY=你的Secret Key
AWS_BUCKET_NAME=你的Bucket名字

相信弄过Actions的各位童鞋们是一定有经验的,所以我就不加教程了。

sw端

原理也是进行网站劫持,代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
const CACHE_NAME = 'ICDNCache';
let cachelist = [];
self.addEventListener('install', async function (installEvent) {
self.skipWaiting();
installEvent.waitUntil(
caches.open(CACHE_NAME)
.then(function (cache) {
console.log('Opened cache');
return cache.addAll(cachelist);
})
);
});
self.addEventListener('fetch', async event => {
try {
event.respondWith(handle(event.request))
} catch (msg) {
event.respondWith(handleerr(event.request, msg))
}
});
const handleerr = async (req, msg) => {
return new Response(`<h1>CDN分流器遇到了致命错误</h1>
<b>${msg}</b>`, { headers: { "content-type": "text/html; charset=utf-8" } })
}
const lfetch = async (urls, url) => {
let controller = new AbortController();
const PauseProgress = async (res) => {
return new Response(await (res).arrayBuffer(), { status: res.status, headers: res.headers });
};
if (!Promise.any) {
Promise.any = function (promises) {
return new Promise((resolve, reject) => {
promises = Array.isArray(promises) ? promises : []
let len = promises.length
let errs = []
if (len === 0) return reject(new AggregateError('All promises were rejected'))
promises.forEach((promise) => {
promise.then(value => {
resolve(value)
}, err => {
len--
errs.push(err)
if (len === 0) {
reject(new AggregateError(errs))
}
})
})
})
}
}
return Promise.any(urls.map(urls => {
return new Promise((resolve, reject) => {
fetch(urls, {
signal: controller.signal
})
.then(PauseProgress)
.then(res => {
if (res.status == 200) {
controller.abort();
resolve(res)
} else {
reject(res)
}
})
})
}))
}
self.addEventListener('fetch', async event => {
event.respondWith(handle(event.request))
});
const fullpath = (path) => {
path = path.split('?')[0].split('#')[0]
if (path.match(/\/$/)) {
path += 'index'
}
if (!path.match(/\.[a-zA-Z]+$/)) {
path += '.html'
}
return path
}

const handle = async(req)=>{
const urlStr = req.url
const urlObj = new URL(urlStr);
const urlPath = urlObj.pathname;
const domain = urlObj.hostname;
//从这里开始
if(domain === ""){//这里写你需要拦截的域名
return lfetch(["{改成你的存储桶url}"+fullpath(urlPath)])//屏蔽了自带的npm劫持,改为存储桶劫持
}
else{
return fetch(req);
}
}

目前暂未实现缓存功能qaq。

新版rightMenu,支持遮罩

参考此文章,这篇文章已经进行了修改:

pace加载条

落樱特效(搭配博客设置食用)

添加js(参考自ichika):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
//樱花

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, 35 * this.s, 35 * 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 - 0.6;
//x轴速度
}
;
break;
case 'fny':
random = 0.8 + Math.random() * 0.7
//y轴速度
ret = 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 < 10; 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;
}

function stopp(e) {
if (!e && document.getElementById("canvas_sakura")) {
var child = document.getElementById("canvas_sakura");
child.parentNode.removeChild(child);
window.cancelAnimationFrame(stop);
} else if (e && !document.getElementById("canvas_sakura")) {
startSakura();
}
}
window.addEventListener("DOMContentLoaded",
startSakura);

fps显示

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
// if(window.localStorage.getItem("fpson")=="1"){
//如果要使博客设置上面的设置项能生效,就把上面一行取消注释
var rAF = function () {
return (
window.requestAnimationFrame ||
window.webkitRequestAnimationFrame ||
function (callback) {
window.setTimeout(callback, 1000 / 60);
}
);
}();
var frame = 0;
var allFrameCount = 0;
var lastTime = Date.now();
var lastFameTime = Date.now();
var loop = function () {
var now = Date.now();
var fs = (now - lastFameTime);
var fps = Math.round(1000 / fs);

lastFameTime = now;
// 不置 0,在动画的开头及结尾记录此值的差值算出 FPS
allFrameCount++;
frame++;

if (now > 1000 + lastTime) {
var fps = Math.round((frame * 1000) / (now - lastTime));
if(fps<=6){
var kd=`<span style="color:#bd0000">卡成ppt</span>`
}
else if(fps<=10){
var kd=`<span style="color:red">电竞级帧率</span>`
}
else if(fps<=14){
var kd=`<span style="color:yellow">难受</span>`
}
else if(fps<24){
var kd=`<span style="color:orange">卡</span>`
}
else if(fps<=40){
var kd=`<span style="color:green">...</span>`
}
else{
var kd=`<span style="color:#425aef">正常</span>`
}
document.getElementById("fps").innerHTML=`FPS:${fps} ${kd}`;
frame = 0;
lastTime = now;
};

rAF(loop);
}

loop();
// }
// else{$("#fps").hide()}

//如果要使博客设置上面的设置项能生效,就把上面两行取消注释

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
document.addEventListener('pjax:complete', fps);
document.addEventListener('DOMContentLoaded', fps);
function fps(){
// if(window.localStorage.getItem("fpson")=="1"){
//如果要使博客设置上面的设置项能生效,就把上面一行取消注释
var rAF = function () {
return (
window.requestAnimationFrame ||
window.webkitRequestAnimationFrame ||
function (callback) {
window.setTimeout(callback, 1000 / 60);
}
);
}();
var frame = 0;
var allFrameCount = 0;
var lastTime = Date.now();
var lastFameTime = Date.now();
var loop = function () {
var now = Date.now();
var fs = (now - lastFameTime);
var fps = Math.round(1000 / fs);

lastFameTime = now;
// 不置 0,在动画的开头及结尾记录此值的差值算出 FPS
allFrameCount++;
frame++;

if (now > 1000 + lastTime) {
var fps = Math.round((frame * 1000) / (now - lastTime));
if(fps<=6){
var kd=`<span style="color:#bd0000">卡成ppt</span>`
}
else if(fps<=10){
var kd=`<span style="color:red">电竞级帧率</span>`
}
else if(fps<=14){
var kd=`<span style="color:yellow">难受</span>`
}
else if(fps<24){
var kd=`<span style="color:orange">卡</span>`
}
else if(fps<=40){
var kd=`<span style="color:green">...</span>`
}
else{
var kd=`<span style="color:#425aef">正常</span>`
}
document.getElementById("fps").innerHTML=`FPS:${fps} ${kd}`;
frame = 0;
lastTime = now;
};

rAF(loop);
}

loop();
// }
// else{$("#fps").hide()}

//如果要使博客设置上面的设置项能生效,就把上面两行取消注释
}

css:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#fps{
position: fixed;
right:10px;
bottom:4px;
z-index: 1919810;
}

[data-theme="light"] #fps{
background-color: var(--lyx-white-acrylic1);
padding: 4px;
border-radius: 4px;
backdrop-filter: blur(10px);
}
[data-theme="dark"] #fps{
background-color: var(--lyx-black-acrylic1);
padding: 4px;
border-radius: 4px;
backdrop-filter: blur(10px);
}

然后在主题配置文件中插入:

1
2
3
4
5
6
7
8
inject:
head:
...
bottom:
- <div id="fps"></div>

注意该功能

公告栏欢迎

自行新建并修改以下js,cv自ichika[doge保命

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
document.addEventListener('pjax:complete', todis);
document.addEventListener('DOMContentLoaded', todis);
function todis(){
$.ajax({
type: 'get',
url: 'https://apis.map.qq.com/ws/location/v1/ip',
data: {
key: 'T3EBZ-TJ7LI-YRBG2-5ZLUR-KD3OS-U6BJO',
output: 'jsonp',
},
dataType: 'jsonp',
success: function (res) {
ipLoacation = res;
function getDistance(e1, n1, e2, n2) {
const R = 6371
const { sin, cos, asin, PI, hypot } = Math

let getPoint = (e, n) => {
e *= PI / 180
n *= PI / 180
return { x: cos(n) * cos(e), y: cos(n) * sin(e), z: sin(n) }
}

let a = getPoint(e1, n1)
let b = getPoint(e2, n2)
let c = hypot(a.x - b.x, a.y - b.y, a.z - b.z)
let r = asin(c / 2) * 2 * R
return Math.round(r);
}

function showWelcome() {

let dist = getDistance(107.38779, 29.70239, ipLoacation.result.location.lng, ipLoacation.result.location.lat);

let pos = ipLoacation.result.ad_info.nation;
let posdesc;
switch (ipLoacation.result.ad_info.nation) {
case "日本":
posdesc = "よろしく,一起去看樱花吗";
break;
case "美国":
posdesc = "Make America Great Again!";
break;
case "英国":
posdesc = "想同你一起夜乘伦敦眼";
break;
case "俄罗斯":
posdesc = "干了这瓶伏特加!";
break;
case "法国":
posdesc = "C'est La Vie";
break;
case "德国":
posdesc = "Die Zeit verging im Fluge.";
break;
case "澳大利亚":
posdesc = "一起去大堡礁吧!";
break;
case "加拿大":
posdesc = "拾起一片枫叶赠予你";
break;
case "中国":
pos = ipLoacation.result.ad_info.province + " " + ipLoacation.result.ad_info.city;
switch (ipLoacation.result.ad_info.province) {
case "北京市":
posdesc = "北——京——欢迎你~~~";
break;
case "天津市":
posdesc = "讲段相声吧。";
break;
case "重庆市":
posdesc = "老乡!!!"
break;
case "河北省":
posdesc = "山势巍巍成壁垒,天下雄关。铁马金戈由此向,无限江山。";
break;
case "山西省":
posdesc = "展开坐具长三尺,已占山河五百余。";
break;
case "内蒙古自治区":
posdesc = "天苍苍,野茫茫,风吹草低见牛羊。";
break;
case "辽宁省":
posdesc = "我想吃烤鸡架!";
break;
case "吉林省":
posdesc = "状元阁就是东北烧烤之王。";
break;
case "黑龙江省":
posdesc = "很喜欢哈尔滨大剧院。";
break;
case "上海市":
posdesc = "众所周知,中国只有两个城市。";
break;
case "江苏省":
switch (ipLoacation.result.ad_info.city) {
case "南京市":
posdesc = "欢迎来自安徽省南京市的小伙伴。";
break;
case "苏州市":
posdesc = "上有天堂,下有苏杭。";
break;
default:
posdesc = "散装是必须要散装的。";
break;
}
break;
case "浙江省":
posdesc = "东风渐绿西湖柳,雁已还人未南归。";
break;
case "安徽省":
posdesc = "蚌埠住了,芜湖起飞。";
break;
case "福建省":
posdesc = "井邑白云间,岩城远带山。";
break;
case "江西省":
posdesc = "落霞与孤鹜齐飞,秋水共长天一色。";
break;
case "山东省":
posdesc = "遥望齐州九点烟,一泓海水杯中泻。";
break;
case "湖北省":
posdesc = "来碗热干面!";
break;
case "湖南省":
posdesc = "74751,长沙斯塔克。";
break;
case "广东省":
posdesc = "老板来两斤福建人。";
break;
case "广西壮族自治区":
posdesc = "桂林山水甲天下。";
break;
case "海南省":
posdesc = "朝观日出逐白浪,夕看云起收霞光。";
break;
case "四川省":
posdesc = "康康川妹子。";
break;
case "贵州省":
posdesc = "茅台,学生,再塞200。";
break;
case "云南省":
posdesc = "玉龙飞舞云缠绕,万仞冰川直耸天。";
break;
case "西藏自治区":
posdesc = "躺在茫茫草原上,仰望蓝天。";
break;
case "陕西省":
posdesc = "来份臊子面加馍。";
break;
case "甘肃省":
posdesc = "羌笛何须怨杨柳,春风不度玉门关。";
break;
case "青海省":
posdesc = "牛肉干和老酸奶都好好吃。";
break;
case "宁夏回族自治区":
posdesc = "大漠孤烟直,长河落日圆。";
break;
case "新疆维吾尔自治区":
posdesc = "驼铃古道丝绸路,胡马犹闻唐汉风。";
break;
case "台湾省":
posdesc = "我在这头,大陆在那头。";
break;
case "香港特别行政区":
posdesc = "永定贼有残留地鬼嚎,迎击光非岁玉。";
break;
case "澳门特别行政区":
posdesc = "性感荷官,在线发牌。";
break;
default:
posdesc = "社会主义大法好。";
break;
}
break;
default:
posdesc = "带我去你的国家逛逛吧。";
break;
}

//判断时间
let timeChange;
let date = new Date();
if (date.getHours()>= 5 && date.getHours() < 11) timeChange = "<span>上午好</span>,一日之计在于晨";
else if (date.getHours()>= 1 && date.getHours() < 13) timeChange = "<span>中午好</span>,该摸鱼吃午饭了";
else if (date.getHours() >= 13 && date.getHours() < 15) timeChange = "<span>下午好</span>,懒懒地睡个午觉吧!";
else if (date.getHours() >= 15 && date.getHours() < 16) timeChange = "<span>三点几啦</span>,饮茶先啦!";
else if (date.getHours() >= 16 && date.getHours() < 19) timeChange = "<span>夕阳无限好!</span>";
else if (date.getHours() >= 19 && date.getHours() < 24) timeChange = "<span>晚上好</span>,夜生活嗨起来!";
else timeChange = "夜深了,早点休息,少熬夜";

document.getElementsByClassName("announcement_content")[0].innerHTML =
`欢迎来自<span>${pos}</span>的小伙伴,${timeChange}<br>
你距离Ariasaka约有<span>${dist}</span>公里,${posdesc}
<br>
<br>
本网站的Twikoo评论系统使用<a href="https://cravatar.cn">Cravatar</a>头像系统,请自行绑定邮箱配置
`;
}
showWelcome()
}
})
function switchPostChart () {
let color = document.documentElement.getAttribute('data-theme') === 'light' ? '#4C4948' : 'rgba(255,255,255,0.7)'
if (document.getElementById('posts-chart') && postsOption) {
try {
let postsOptionNew = postsOption
postsOptionNew.title.textStyle.color = color
postsOptionNew.xAxis.nameTextStyle.color = color
postsOptionNew.yAxis.nameTextStyle.color = color
postsOptionNew.xAxis.axisLabel.color = color
postsOptionNew.yAxis.axisLabel.color = color
postsOptionNew.xAxis.axisLine.lineStyle.color = color
postsOptionNew.yAxis.axisLine.lineStyle.color = color
postsOptionNew.series[0].markLine.data[0].label.color = color
postsChart.setOption(postsOptionNew)
} catch (error) {
console.log(error)
}
}
if (document.getElementById('tags-chart') && tagsOption) {
try {
let tagsOptionNew = tagsOption
tagsOptionNew.title.textStyle.color = color
tagsOptionNew.xAxis.nameTextStyle.color = color
tagsOptionNew.yAxis.nameTextStyle.color = color
tagsOptionNew.xAxis.axisLabel.color = color
tagsOptionNew.yAxis.axisLabel.color = color
tagsOptionNew.xAxis.axisLine.lineStyle.color = color
tagsOptionNew.yAxis.axisLine.lineStyle.color = color
tagsOptionNew.series[0].markLine.data[0].label.color = color
tagsChart.setOption(tagsOptionNew)
} catch (error) {
console.log(error)
}
}
if (document.getElementById('categories-chart') && categoriesOption) {
try {
let categoriesOptionNew = categoriesOption
categoriesOptionNew.title.textStyle.color = color
categoriesOptionNew.legend.textStyle.color = color
if (!categoryParentFlag) { categoriesOptionNew.series[0].label.color = color }
categoriesChart.setOption(categoriesOptionNew)
} catch (error) {
console.log(error)
}
}
}
document.querySelector(".rightMenu-item:has(.fa-moon)").addEventListener("click", function () { setTimeout(switchPostChart, 100) })
document.getElementById("con-mode").addEventListener("click", function () { setTimeout(switchPostChart, 100) })}
//

更好的首页轮播

基于Akilar的npm版进行修改,部分代码~~(扒~~来自Leonus,部分功能进行了精简:

先进行安装

1
npm i -s hexo-butterfly-swiper-lyx

注意,如果安装过hexo-butterfly-swiper请先卸载:

1
npm un -s hexo-butterfly-swiper

然后在主题_config.yml里编写:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# hexo-butterfly-swiper-lyx
# see https://yisous.xyz/posts/670e47f/#%E6%9B%B4%E5%A5%BD%E7%9A%84%E9%A6%96%E9%A1%B5%E8%BD%AE%E6%92%AD
swiper:
enable: true # 开关
priority: 5 # 过滤器优先权
enable_page: all # 应用页面
layout: # 挂载容器类型
type: class
name: swiper-div
index: 0
default_descr:
swiper_css: https://cdnjs.cloudflare.com/ajax/libs/Swiper/5.4.5/css/swiper.min.css
swiper_js: https://cdnjs.cloudflare.com/ajax/libs/Swiper/5.4.5/js/swiper.min.js
custom_css: https://npm.elemecdn.com/hexo-butterfly-swiper-lyx/lib/swiperstyle.css
custom_js: https://npm.elemecdn.com/hexo-butterfly-swiper-lyx/lib/swiper_init.js

注意,因为切换键采用了自己的配色方案,建议添加css覆盖掉:

1
2
3
.swiper-button-next:after, .swiper-button-prev:after{
color:#66ccff!important; /*自己改*/
}

除此之外,在1.0.2版本中,为了和原版描述区分开来,所以swiper的描述项改为了swiper_description,当然你也可以装回1.0.1

1
npm install -s hexo-butterfly-swiper-lyx@1.0.1

Twikoo Magic

扩展更多表情包,参考: