日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

hexo博客主题推荐_wordpress社交主题(Hexo系列)

發布時間:2023/12/19 综合教程 19 生活家
生活随笔 收集整理的這篇文章主要介紹了 hexo博客主题推荐_wordpress社交主题(Hexo系列) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

個人博客

個人博客: https://www.crystalblog.xyz/

備用地址: https://wang-qz.gitee.io/crystal-blog/

上篇hexo博客搭建及主題優化(一)
下篇hexo博客搭建及主題優化(三)

主題優化二

21. 網站log設置

主題目錄下的_config.yml 配置文件中:

# 配置網站favicon和網站LOGO
## 本地
#favicon: /favicon.png
#logo: /medias/logo.png
# 此處我用的CDN,也可以使用本地文件
favicon: https://cdn.jsdelivr.net/gh/guixinchn/image/blog/favicon.png
logo: https://cdn.jsdelivr.net/gh/guixinchn/image/blog/logo.png

圖片資源在主題目錄的\themes\hexo-theme-matery\source\medias下面 , 也可以使用外鏈圖片.

22. 網站動態標題行

實現方法,引入 js 文件,在主題文件下的 /source/js/ 下新建 funnyTitle.js,增加以下代碼:

var OriginTitle = document.title;
 var titleTime;
 document.addEventListener('visibilitychange', function () { 
   
     if (document.hidden) { 
   
         $('[rel="icon"]').attr('href', "https://cdn.jsdelivr.net/gh/guixinchn/image/blog/favicon.png");
         document.title = '我相信你還會回來的!';
         clearTimeout(titleTime);
     }
     else { 
   
         $('[rel="icon"]').attr('href', "https://cdn.jsdelivr.net/gh/guixinchn/image/blog/favicon.png");
         document.title = '哈哈,我就知道!' + OriginTitle;
         titleTime = setTimeout(function () { 
   
             document.title = OriginTitle;
         }, 2000);
     }
 });

然后在主題目錄下的/layout/layout.ejs 引入

<script src="<%- theme.jsDelivr.url %><%- url_for('/js/funnyTitle.js') %>"></script>

23. about頁面添加個人簡歷

打開主題目錄下的 /layout/about.ejs 文件,新增如下代碼:

<div class="card-content article-card-content">
   <div class="title center-align" data-aos="zoom-in-up">
      <i class="fa fa-address-book"></i>&nbsp;&nbsp;<%- __('個人簡歷') %>
   </div>
   <div id="articleContent" data-aos="fade-up">
      <%- page.content %>
   </div>
</div>

在主題目錄下的/layout/about.ejs 文件里面關于下面代碼中的profile相關信息從主題的 _config.yml 配置文件中獲取.

<div class="profile center-align">
    <div class="avatar">
        <img src="<%- theme.jsDelivr.url %><%- url_for(theme.profile.avatar) %>" alt="<%- config.author %>" class="circle responsive-img avatar-img">
    </div>
    <div class="author">
        <div class="post-statis hide-on-large-only" data-aos="zoom-in-right">
            <%- partial('_partial/post-statis') %>
        </div>
        <div class="title"><%- config.author %></div>
        <div class="career"><%- theme.profile.career %></div>
        <div class="social-link hide-on-large-only" data-aos="zoom-in-left">
            <%- partial('_partial/social-link') %>
        </div>
    </div>
</div>

主題目錄下的 _config.yml 配置文件中profile信息配置, 可以修改…

# profile in about page, including avatars, career, and personal introductions.
# 在”關于”頁面中配置個人信息,包括頭像、職業和個人介紹.
profile:
  avatar: /medias/avatar.jpg
  career: Software Engineer
  introduction: If you wish to succeed, you should use persistence as your good friend, experience as your reference, prudence as your brother and hope as your sentry.

24. 404頁面

原來的主題沒有404頁面,首先在主題目錄下的/source/目錄下新建一個404.md,內容如下:

---
title: 404
date: 2017-07-19 16:41:10
type: "404"
layout: "404"
description: "你訪問的頁面被外星人叼走了 :("
---

然后在主題目錄下新建一個/layout/404.ejs文件,內容如下:

<style type="text/css"> /* don't remove. */ .about-cover { 
      height: 90.2vh; } </style>
<div class="bg-cover pd-header about-cover">
    <div class="container">
        <div class="row">
            <div class="col s10 offset-s1 m8 offset-m2 l8 offset-l2">
                <div class="brand">
                    <div class="title center-align">
                        404
                    </div>
                    <div class="description center-align">
                        <%= page.description %>
                    </div>
                </div>
            </div>
        </div>
    </div>
</div>

<% if (theme.banner.enable) { %>
    <script> // 每天切換 banner 圖. Switch banner image every day. var bannerUrl = "<%- theme.jsDelivr.url %><%- url_for('/medias/banner/') %>" + new Date().getDay() + '.jpg'; $('.bg-cover').css('background-image', 'url(' + bannerUrl + ')'); </script>
<% } else { %>
    <script> $('.bg-cover').css('background-image', 'url(<%- theme.jsDelivr.url %><%- url_for('/medias/banner/0.jpg') %>)'); </script>
<% } %>

25. 網站頁腳修改

根據自己需要修改主題目錄下的/layout/_partial/footer.ejs文件, 可以設置站點訪問量, 訪問人數, 字數統計, 站點運行時間, 網站備案等信息.

<footer class="page-footer bg-color">
<% if (theme.music.enable && theme.music.fixed) { %>
<%- partial('_widget/music') %>
<% } %>
<div class="container row center-align">
<div class="col s12 m8 l8 copy-right">
Copyright&nbsp;&copy;
<% if (theme.time.year !== new Date().getFullYear()) { %>
<span id="year"><%- theme.time.year %>-<%- new Date().getFullYear() %></span>
<% } else { %>
<span id="year"><%- theme.time.year %></span>
<% } %>
<i class="fa fa-heart"></i>
<a href="<%- url_for('/about') %>" target="_blank"><%- config.author %></a>
|&nbsp;Powered by&nbsp;<a  target="_blank">Hexo</a>
|&nbsp;&nbsp;<a  target="_blank">Matery</a>
<br>
<% if (theme.postInfo.totalCount) { %>
<span>
&nbsp;  <i class="fas fa-chart-area"></i>&nbsp;<%- __('siteTotalWords') %>:&nbsp;<span class="white-color"><%= totalcount(site) %></span>
<span/>
<% } %>
<% let socialClass = '' %>
<% if (theme.busuanziStatistics && theme.busuanziStatistics.enable) { %>
<% socialClass = 'social-statis' %>
<% } %>
<% if (theme.busuanziStatistics && theme.busuanziStatistics.totalTraffic) { %>
<span id="busuanzi_container_site_pv3">
&nbsp;|&nbsp;<i class="far fa-eye"></i>&nbsp;<%- __('siteTotalVisits') %>:&nbsp;<span id="busuanzi_value_site_pv" class="white-color"><%= totalcount(site) %></span>
</span>
<% } %>
<% if (theme.busuanziStatistics && theme.busuanziStatistics.totalNumberOfvisitors) { %>
<span id="busuanzi_container_site_uv3">
&nbsp;|&nbsp;<i class="fas fa-users"></i>&nbsp;<%- __('siteTotalVisitors') %>:&nbsp;<span id="busuanzi_value_site_uv" class="white-color"><%= totalcount(site) %></span>
</span>
<% } %>
<br>
<!-- 運行天數提醒. -->
<% if (theme.time.enable) { %>
<span id="sitetime"> Loading ...</span>
<script> var calcSiteTime = function () { 
 var seconds = 1000; var minutes = seconds * 60; var hours = minutes * 60; var days = hours * 24; var years = days * 365; var today = new Date(); var startYear = "<%- theme.time.year %>"; var startMonth = "<%- theme.time.month %>"; var startDate = "<%- theme.time.date %>"; var startHour = "<%- theme.time.hour %>"; var startMinute = "<%- theme.time.minute %>"; var startSecond = "<%- theme.time.second %>"; var todayYear = today.getFullYear(); var todayMonth = today.getMonth() + 1; var todayDate = today.getDate(); var todayHour = today.getHours(); var todayMinute = today.getMinutes(); var todaySecond = today.getSeconds(); var t1 = Date.UTC(startYear, startMonth, startDate, startHour, startMinute, startSecond); var t2 = Date.UTC(todayYear, todayMonth, todayDate, todayHour, todayMinute, todaySecond); var diff = t2 - t1; var diffYears = Math.floor(diff / years); var diffDays = Math.floor((diff / days) - diffYears * 365); var diffHours = Math.floor((diff / hours) - diffYears * 365 * 24 - diffDays * 24); var diffMinutes = Math.floor((diff / minutes) - diffYears * 365 * 24 * 60 - diffDays * 24 * 60 - diffHours * 60); var diffSeconds = Math.floor((diff / seconds) - diffYears * 365 * 24 * 60 * 60 - diffDays * 24 * 60 * 60 - diffHours * 60 * 60 - diffMinutes * 60); // 區分是否有年份. var language = '<%- config.language %>'; if (startYear === String(todayYear)) { 
 document.getElementById("year").innerHTML = todayYear; var daysTip = 'This site has been running for ' + diffDays + ' days'; if (language === 'zh-CN') { 
 daysTip = '本站已運行 ' + diffDays + ' 天'; } else if (language === 'zh-HK') { 
 daysTip = '本站已運行 ' + diffDays + ' 天'; } document.getElementById("sitetime").innerHTML = daysTip; } else { 
 document.getElementById("year").innerHTML = startYear + " - " + todayYear; var yearsAndDaysTip = 'This site has been running for ' + diffYears + ' years and ' + diffDays + ' days'; if (language === 'zh-CN') { 
 yearsAndDaysTip = '本站已運行 ' + diffYears + ' 年 ' + diffDays + ' 天 ' + diffHours + ' 小時 ' + diffMinutes + ' 分鐘 ' + diffSeconds + ' 秒'; } else if (language === 'zh-HK') { 
 yearsAndDaysTip = '本站已運行 ' + diffYears + ' 年 ' + diffDays + ' 天'; } document.getElementById("sitetime").innerHTML = yearsAndDaysTip; } } var timer = setInterval(calcSiteTime); // calcSiteTime(); </script>
<% } %>
&nbsp;|&nbsp;
<% if (theme.icp.enable) { %>
<span id="icp">
<img src="<%- theme.jsDelivr.url %><%- url_for('/medias/icp.png') %>"/>
<a href="<%- url_for(theme.icp.url) %>" target="_blank"><%=                                 theme.icp.text %></a>
</span>
<% } %>
</div>
<div class="col s12 m4 l4 social-link <%- socialClass %>">
<%- partial('_partial/social-link') %>
</div>
</div>
</footer>

還可以添加百度不蒜子統計

找到/layout/_partial/footer.ejs 文件,修改對應樣式為

<!--總訪問人數-->
<% if (theme.busuanziStatistics && theme.busuanziStatistics.totalNumberOfvisitors) { 
 %>
<span id="busuanzi_container_site_uv">
&nbsp;|&nbsp;<i class="fas fa-users"></i>&nbsp;<%- __('siteTotalVisitors') %>:&nbsp;<span
id="busuanzi_value_site_uv" class="white-color"></span>
</span>
<% } %>
<!--最后加上-->
<script>
let _hmt = _hmt || [];
(function () { 

var hm = document.createElement("script");
hm.src = "https://hm.baidu.com/hm.js?147475454185ebcf440a27cc35e793ef";
var s = document.getElementsByTagName("script")[0];
s.parentNode.insertBefore(hm, s);
})();
</script>

26. 添加動漫人物

安裝插件hexo-helper-live2d

npm install --save hexo-helper-live2d

安裝下載動畫人物庫, 動畫人物有很多, 可以網上查詢資料, 下面推薦幾種.

npm install --save live2d-widget-model-shizuku #課桌女孩
npm install --save live2d-widget-model-hibiki  #御姐
npm install --save live2d-widget-model-wanko   #狗狗
npm install --save live2d-widget-model-haruto  #海軍服女孩
npm install --save live2d-widget-model-miku    #蘿莉

博客根目錄_config.yml文件配置:

## 添加動畫live2d模塊 npm install --save hexo-helper-live2d
## 下載動畫人物庫 npm install live2d-widget-model-z16 -D
live2d:
enable: true
scriptFrom: local # 默認
pluginRootPath: live2dw/ # 插件在站點上的根目錄(相對路徑)
pluginJsPath: lib/ # 腳本文件相對與插件根目錄路徑
pluginModelPath: assets/ # 模型文件相對與插件根目錄路徑
tagMode: false # 標簽模式, 是否僅替換 live2d tag標簽而非插入到所有頁面中
debug: false # 調試, 是否在控制臺輸出日志
model:
use: live2d-widget-model-miku
display:
position: right #動畫位置
width: 150
height: 190
# 位置配置,這個在左側邊欄位置很居中
hOffset: 50  # 調節水平位置
vOffset: -5  # 調節垂直位置
mobile:
show: false # 是否在移動設備上顯示
scale: 0.5 # 移動設備上的縮放
react:
opacityDefault: 0.7
opacityOnHover: 0.8

27. 雪花和櫻花效果

添加雪花飄落效果

在主題目錄下新增/source/js/snow.js文件, 添加內容:

/*樣式一*/
(function ($) { 

$.fn.snow = function (options) { 

var $flake = $('<div id="snowbox" />').css({ 

'position': 'absolute',
'z-index': '9999',
'top': '-50px'
}).html('❄'),
documentHeight = $(document).height(),
documentWidth = $(document).width(),
defaults = { 

minSize: 10,
maxSize: 20,
newOn: 1000,
flakeColor: "#AFDAEF" /* 此處可以定義雪花顏色,若要白色可以改為#FFFFFF */
},
options = $.extend({ 
}, defaults, options);
var interval = setInterval(function () { 

var startPositionLeft = Math.random() * documentWidth - 100,
startOpacity = 0.5 + Math.random(),
sizeFlake = options.minSize + Math.random() * options.maxSize,
endPositionTop = documentHeight - 200,
endPositionLeft = startPositionLeft - 500 + Math.random() * 500,
durationFall = documentHeight * 10 + Math.random() * 5000;
$flake.clone().appendTo('body').css({ 

left: startPositionLeft,
opacity: startOpacity,
'font-size': sizeFlake,
color: options.flakeColor
}).animate({ 

top: endPositionTop,
left: endPositionLeft,
opacity: 0.2
}, durationFall, 'linear', function () { 

$(this).remove()
});
}, options.newOn);
};
})(jQuery);
$(function () { 

$.fn.snow({ 

minSize: 5, /* 定義雪花最小尺寸 */
maxSize: 50,/* 定義雪花最大尺寸 */
newOn: 300  /* 定義密集程度,數字越小越密集 */
});
});
/*樣式二*/
/* 控制下雪 */
function snowFall(snow) { 

/* 可配置屬性 */
snow = snow || { 
};
this.maxFlake = snow.maxFlake || 200;   /* 最多片數 */
this.flakeSize = snow.flakeSize || 10;  /* 雪花形狀 */
this.fallSpeed = snow.fallSpeed || 1;   /* 墜落速度 */
}
/* 兼容寫法 */
requestAnimationFrame = window.requestAnimationFrame ||
window.mozRequestAnimationFrame ||
window.webkitRequestAnimationFrame ||
window.msRequestAnimationFrame ||
window.oRequestAnimationFrame ||
function (callback) { 

setTimeout(callback, 1000 / 60);
};
cancelAnimationFrame = window.cancelAnimationFrame ||
window.mozCancelAnimationFrame ||
window.webkitCancelAnimationFrame ||
window.msCancelAnimationFrame ||
window.oCancelAnimationFrame;
/* 開始下雪 */
snowFall.prototype.start = function () { 

/* 創建畫布 */
snowCanvas.apply(this);
/* 創建雪花形狀 */
createFlakes.apply(this);
/* 畫雪 */
drawSnow.apply(this)
}
/* 創建畫布 */
function snowCanvas() { 

/* 添加Dom結點 */
var snowcanvas = document.createElement("canvas");
snowcanvas.id = "snowfall";
snowcanvas.width = window.innerWidth;
snowcanvas.height = document.body.clientHeight;
snowcanvas.setAttribute("style", "position:absolute; top: 0; left: 0; 
z-index: 1; pointer-events: none;");
document.getElementsByTagName("body")[0].appendChild(snowcanvas);
this.canvas = snowcanvas;
this.ctx = snowcanvas.getContext("2d");
/* 窗口大小改變的處理 */
window.onresize = function () { 

snowcanvas.width = window.innerWidth;
/* snowcanvas.height = window.innerHeight */
}
}
/* 雪運動對象 */
function flakeMove(canvasWidth, canvasHeight, flakeSize, fallSpeed) { 

this.x = Math.floor(Math.random() * canvasWidth);   /* x坐標 */
this.y = Math.floor(Math.random() * canvasHeight);  /* y坐標 */
this.size = Math.random() * flakeSize + 2;          /* 形狀 */
this.maxSize = flakeSize;                           /* 最大形狀 */
this.speed = Math.random() * 1 + fallSpeed;         /* 墜落速度 */
this.fallSpeed = fallSpeed;                         /* 墜落速度 */
this.velY = this.speed;                             /* Y方向速度 */
this.velX = 0;                                      /* X方向速度 */
this.stepSize = Math.random() / 30;                 /* 步長 */
this.step = 0                                       /* 步數 */
}
flakeMove.prototype.update = function () { 

var x = this.x,
y = this.y;
/* 左右擺動(余弦) */
this.velX *= 0.98;
if (this.velY <= this.speed) { 

this.velY = this.speed
}
this.velX += Math.cos(this.step += .05) * this.stepSize;
this.y += this.velY;
this.x += this.velX;
/* 飛出邊界的處理 */
if (this.x >= canvas.width || this.x <= 0 || this.y >= canvas.height || this.y <= 0) { 

this.reset(canvas.width, canvas.height)
}
};
/* 飛出邊界-放置最頂端繼續墜落 */
flakeMove.prototype.reset = function (width, height) { 

this.x = Math.floor(Math.random() * width);
this.y = 0;
this.size = Math.random() * this.maxSize + 2;
this.speed = Math.random() * 1 + this.fallSpeed;
this.velY = this.speed;
this.velX = 0;
};
// 渲染雪花-隨機形狀(此處可修改雪花顏色!!!)
flakeMove.prototype.render = function (ctx) { 

var snowFlake = ctx.createRadialGradient(this.x, this.y, 0, this.x, this.y, this.size);
snowFlake.addColorStop(0, "rgba(255, 255, 255, 0.9)");  /* 此處是雪花顏色,默認是白色 */
snowFlake.addColorStop(.5, "rgba(255, 255, 255, 0.5)"); /* 若要改為其他顏色,請自行查 */
snowFlake.addColorStop(1, "rgba(255, 255, 255, 0)");    /* 找16進制的RGB 顏色代碼。 */
ctx.save();
ctx.fillStyle = snowFlake;
ctx.beginPath();
ctx.arc(this.x, this.y, this.size, 0, Math.PI * 2);
ctx.fill();
ctx.restore();
};
/* 創建雪花-定義形狀 */
function createFlakes() { 

var maxFlake = this.maxFlake,
flakes = this.flakes = [],
canvas = this.canvas;
for (var i = 0; i < maxFlake; i++) { 

flakes.push(new flakeMove(canvas.width, canvas.height, this.flakeSize, this.fallSpeed))
}
}
/* 畫雪 */
function drawSnow() { 

var maxFlake = this.maxFlake,
flakes = this.flakes;
ctx = this.ctx, canvas = this.canvas, that = this;
/* 清空雪花 */
ctx.clearRect(0, 0, canvas.width, canvas.height);
for (var e = 0; e < maxFlake; e++) { 

flakes[e].update();
flakes[e].render(ctx);
}
/* 一幀一幀的畫 */
this.loop = requestAnimationFrame(function () { 

drawSnow.apply(that);
});
}
/* 調用及控制方法 */
var snow = new snowFall({ 
maxFlake: 60});
snow.start();

在主題目錄下/layout/layout.ejs里添加如下代碼:

<!-- 雪花特效 -->
<% if (theme.snow.enable) { %>
<script src="<%-%20theme.jsDelivr.url%20%><%-%20url_for('/js/snow.js'%20)%20%>"></script>
<% } %>

在主題目錄下_config.yml里配置:

# 雪花特效
snow:
enable: true

添加櫻花飄落效果

在主題目錄下新增/source/js/sakura.js文件, 添加內容:

var stop, staticx;
var img = new Image();
img.src = "";
function Sakura(x, y, s, r, fn) { 

this.x = x;
this.y = y;
this.s = s;
this.r = r;
this.fn = fn;
}
Sakura.prototype.draw = function (cxt) { 

cxt.save();
var xc = 40 * this.s / 4;
cxt.translate(this.x, this.y);
cxt.rotate(this.r);
cxt.drawImage(img, 0, 0, 40 * this.s, 40 * this.s)
cxt.restore();
}
Sakura.prototype.update = function () { 

this.x = this.fn.x(this.x, this.y);
this.y = this.fn.y(this.y, this.y);
this.r = this.fn.r(this.r);
if (this.x > window.innerWidth || this.x < 0 || this.y > window.innerHeight || this.y < 0) { 

this.r = getRandom('fnr');
if (Math.random() > 0.4) { 

this.x = getRandom('x');
this.y = 0;
this.s = getRandom('s');
this.r = getRandom('r');
} else { 

this.x = window.innerWidth;
this.y = getRandom('y');
this.s = getRandom('s');
this.r = getRandom('r');
}
}
}
SakuraList = function () { 

this.list = [];
}
SakuraList.prototype.push = function (sakura) { 

this.list.push(sakura);
}
SakuraList.prototype.update = function () { 

for (var i = 0, len = this.list.length; i < len; i++) { 

this.list[i].update();
}
}
SakuraList.prototype.draw = function (cxt) { 

for (var i = 0, len = this.list.length; i < len; i++) { 

this.list[i].draw(cxt);
}
}
SakuraList.prototype.get = function (i) { 

return this.list[i];
}
SakuraList.prototype.size = function () { 

return this.list.length;
}
function getRandom(option) { 

var ret, random;
switch (option) { 

case 'x':
ret = Math.random() * window.innerWidth;
break;
case 'y':
ret = Math.random() * window.innerHeight;
break;
case 's':
ret = Math.random();
break;
case 'r':
ret = Math.random() * 6;
break;
case 'fnx':
random = -0.5 + Math.random() * 1;
ret = function (x, y) { 

return x + 0.5 * random - 1.7;
};
break;
case 'fny':
random = 1.5 + Math.random() * 0.7
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 < 50; i++) { 

var sakura, randomX, randomY, randomS, randomR, randomFnx, randomFny;
randomX = getRandom('x');
randomY = getRandom('y');
randomR = getRandom('r');
randomS = getRandom('s');
randomFnx = getRandom('fnx');
randomFny = getRandom('fny');
randomFnR = getRandom('fnr');
sakura = new Sakura(randomX, randomY, randomS, randomR, { 

x: randomFnx,
y: randomFny,
r: randomFnR
});
sakura.draw(cxt);
sakuraList.push(sakura);
}
stop = requestAnimationFrame(function () { 

cxt.clearRect(0, 0, canvas.width, canvas.height);
sakuraList.update();
sakuraList.draw(cxt);
stop = requestAnimationFrame(arguments.callee);
})
}
window.onresize = function () { 

var canvasSnow = document.getElementById('canvas_snow');
}
img.onload = function () { 

startSakura();
}
function stopp() { 

if (staticx) { 

var child = document.getElementById("canvas_sakura");
child.parentNode.removeChild(child);
window.cancelAnimationFrame(stop);
staticx = false;
} else { 

startSakura();
}
}

在主題目錄下/layout/layout.ejs里添加如下代碼:

<!-- 櫻花特效 -->
<% if (theme.sakura.enable) { %>
<script src="<%-%20theme.jsDelivr.url%20%><%-%20url_for('/js/sakura.js')%20%>"></script>
<% } %>

在主題目錄下_config.yml里配置:

# 櫻花特效
sakura:
enable: true

28. 鼠標點擊愛心效果

鼠標點擊樣式1

在主題目錄下/source/libs/others/clicklove.js文件中為鼠標點擊愛心效果代碼.

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

鼠標點擊樣式2

在主題目錄下/source/js/wenzi.js文件中為鼠標點擊愛心效果代碼.

/* 鼠標點擊文字特效 */
var a_idx = 0;
jQuery(document).ready(function ($) { 

$("body").click(function (e) { 

// var a = new Array("❤富強❤","❤民主❤","❤文明❤","❤和諧❤","❤自由❤","❤平等❤","❤公正❤","❤法治❤","❤愛國❤","❤敬業❤","❤誠信❤","❤友善❤");
var a = new Array("富強", "民主", "文明", "和諧", "自由", "平等", "公正", "法治", "愛國", "敬業", "誠信", "友善");
var $i = $("<span></span>").text(a[a_idx]);
a_idx = (a_idx + 1) % a.length;
var x = e.pageX,
y = e.pageY;
$i.css({ 

"z-index": 
999999999999999999999999999999999999999999999999999999999999999999999,
"top": y - 20,
"left": x,
"position": "absolute",
"font-weight": "bold",
"color": "rgb(" + ~~(255 * Math.random()) + "," + ~~(255 * Math.random()) 
+ "," + ~~(255 * Math.random()) + ")"
});
$("body").append($i);
$i.animate({ 

"top": y - 180,
"opacity": 0
},
1500,
function () { 

$i.remove();
});
});
});

在主題目錄下/layout/layout.ejs里添加如下代碼:

<!-- 鼠標點擊特效 -->
<% if (theme.wenzi.enable) { %>
<script src="<%-%20theme.jsDelivr.url%20%><%-%20url_for('/js/wenzi.js')%20%>"></script>
<% } %>

在主題目錄下_config.yml里配置:

# 鼠標點擊特效
wenzi:
enable: true

29. 修改博客文章模板

為了新建文章方便,我們可以修改一下文章模板,可以將/scaffolds/post.md修改為如下代碼:

title: {
{ title }} 
date: {
{ date }} 
author: 
img: 
cover: false
coverImg: 
top: false
toc: true 
mathjax: false 
password: 
summary: 
keywords: 
tags: 
categories: 

30. 在線編輯hexo博客

hexo編輯文章時,其原生方式不便利,官網提供了一款插件hexo-admin界面化了markdown編輯器.

首先安裝hexo-admin插件

npm install --save hexo-admin

然后啟動 hexo s, 訪問 http://127.0.0.1:4000/crystalBlog/admin 就可方便快捷的進行博文編輯了.

編輯后還可以快速部署發布. 不過還是更喜歡在typora上面寫markdown語法, 如果部署在自己的服務器上面可以使用該功能, 部署在gitee或github上還是無法使用.

31. 站點統計不顯示問題

有時候請求busuanzi數據比較慢,然后瀏覽量和訪問人數就會隱藏,可能是默認的,在matery.css中增加以下代碼可以讓它一直顯示.

#busuanzi_container_site_pv, #busuanzi_value_site_pv, #busuanzi_container_site_uv { 

display: inline !important;
}

32. 文章鏈接部分超長處理

/source/css/matery.css中增加以下代碼:

/*文章鏈接超長部分隱藏*/
.reprint__type { 

display: inline-block;
width: 100%;
overflow: hidden;
}

33. 靜態/動態彩帶, 背景canvas

背景靜態彩帶

主題目錄下的/layout/layout.ejs 文件主題目錄下_config.yml中靜態彩帶的配置項:

<!--背景靜止彩帶-->
<% if (theme.ribbon.enable) { %>
<% var ribbonSrc = theme.ribbon.clickChange ? theme.libs.js.ribbon : theme.libs.js.ribbonRefresh; %>
<script type="text/javascript" size="<%- theme.ribbon.size %>" alpha='<%- theme.ribbon.alpha %>'
zIndex="<%- theme.ribbon.zIndex %>" src="<%-%20theme.jsDelivr.url%20%><%-%20url_for(ribbonSrc)%20%>" async="async"></script>
<% } %>

主題目錄下_config.yml中靜態彩帶的配置項:

# 背景靜止彩帶.
ribbon:
enable: false  # 改為true即可開啟背景靜態彩帶
size: 150 # 彩帶大小, 默認: 90.
alpha: 0.6 # 彩帶透明度 (0 ~ 1), 默認: 0.6.
zIndex: -1 # 背景的z-index屬性,css屬性用于控制所在層的位置, 默認: -1.
clickChange: false  # 設置是否每次點擊都更換彩帶.

背景動態彩帶

主題目錄下的/layout/layout.ejs 文件主題目錄下_config.yml中動態彩帶的配置項:

<!--背景動態彩帶-->
<% if (theme.ribbon_dynamic.enable) { %>
<script type="text/javascript" src="<%-%20theme.jsDelivr.url%20%><%-%20url_for(theme.libs.js.ribbon_dynamic)%20%>" async="async"></script>
<% } %>

主題目錄下_config.yml中動態彩帶的配置項:

# 背景動態彩帶.
ribbon_dynamic:
enable: true # 改為true即可開啟背景動態彩帶

背景canvas

主題目錄下的/layout/layout.ejs 文件主題目錄下_config.ymlcanvas的配置項:

<!--背景靜止彩帶-->
<% if (theme.ribbon.enable) { %>
<% var ribbonSrc = theme.ribbon.clickChange ? theme.libs.js.ribbon : theme.libs.js.ribbonRefresh; %>
<script type="text/javascript" size="<%- theme.ribbon.size %>" alpha='<%- theme.ribbon.alpha %>'
zIndex="<%- theme.ribbon.zIndex %>" src="<%-%20theme.jsDelivr.url%20%><%-%20url_for(ribbonSrc)%20%>" async="async"></script>
<% } %>

主題目錄下_config.ymlcanvas的配置項:

#背景canvas-nest
canvas_nest:
enable: true
color: 0,0,255 # 線條顏色, 默認: '0,0,0' ;三個數字分別為(R,G,B),注意用,分割
pointColor: 0,0,255 # 交點顏色, 默認: '0,0,0' ;三個數字分別為(R,G,B),注意用,分割
opacity: 0.7 # 線條透明度(0~1), 默認: 0.5
zIndex: -1 # 背景的 z-index 屬性,css 屬性用于控制所在層的位置, 默認: -1.
count: 99 # 線條的總數量, 默認: 99

主題目錄下/layout/layout.ejs 是全局布局文件, 可以自己添加自定義效果, 方式同上面添加雪花飄落.

34. 提取相冊(壁紙)

新建相冊(壁紙)文件

hexo new page wallpaper

修改主題目錄下的_config.yml文件, 我的是提取到清單-相冊導航處.

Lists:  ##清單
url: /
icon: fas fa-list
children:
- name: 音樂
url: /musics
icon: fas fa-music
- name: 電影
url: /movies
icon: fas fa-film
- name: 閱讀
url: /books
icon: fas fa-book
- name: 壁紙
url: /wallpaper
icon: fas fa-image

修改站點 /galleries/index.md文件

---
title: 壁紙
date: 2019-02-04 21:35:22
layout: wallpaper
---

主題目錄下新建/layout/wallpaper.ejs文件,添加內容如下:

<style type="text/css"> /* don't remove. */ .about-cover { 
 height: 75vh; } </style>
<%- partial('_partial/bg-cover') %>
<!--下面就是提取博客自帶相冊功能的代碼-->
<main class="content">
<% if (theme.myGallery && theme.myGallery.enable) { %>
<%- partial('_widget/my-gallery') %>
<% } %>
</main>
<% if (page.total > 1) { %>
<%- partial('_partial/paging') %>
<% } %>

同時注釋主題目錄下的/layout/about.ejs文件的如下部分:

<!--gallery功能遷移到[清單-相冊]導航處-->
<!--<% if (theme.myGallery && theme.myGallery.enable) { %> <%- partial('_widget/my-gallery') %> <% } %>-->

相冊讀取的圖片配置路徑在主題路徑下的_config.yml文件中:

# 在“關于”頁面配置"我的相冊"圖片,如果你不需要這些信息則可以將其設置為不激活或者將其刪除.
myGallery:
enable: true
data:
- /medias/featureimages/0.jpg
- /medias/featureimages/1.jpg
- /medias/featureimages/2.jpg

修改相冊布局, 找到/source/css/matery.css 文件,修改如下部分:

.my-gallery { 

margin: 4.5rem auto 1rem;
padding: 0 1.2rem; /*這是顯示寬度,前邊是頁面寬度,后邊是圖片寬度*/
max-width: 1100px;
/*position: relative;*/
}
.my-gallery .photo { 

margin: .5rem 0; /*這是上下兩行的行距*/
/*position: relative; overflow: hidden;*/
}
.my-gallery .photo img { 

width: 100%;
height: 200px; /*限制高度,使同行保持等高,不然會很亂*/
border-radius: 10px;
cursor: pointer;
}

35. 添加相冊列表

相冊列表可以參考博客的友情鏈接界面, 將友鏈信息存放在/source/_data/friends.json文件中, 然后hexo會按照friends.ejs模板文件里的結構渲染出來友鏈列表. 效果如下:

原理其實就是三個a標簽, 里面包含頭像, 地址等信息, 點擊后跳轉到對于的地址. 那么我們也可以自定義一個相冊列表的配置文件(galleries.json)和模板文件(galleries.ejs), 然后hexo讀取配置文件, 自動生成相冊列表界面, 如果可以這樣優化, 后面新增相冊就只需要在配置文件galleries.json中維護相冊信息即可. (增刪改)

那我們說干就干, 下面開始咯.

添加清單-相冊菜單

這里要修改幾個文件:

主題目錄下的配置文件_config.yml ,不要跟站點根目錄下的同名文件搞混了,在menu下添加以下代碼:

menu: 
Lists:  ##清單
url: /crystal-blog
icon: fas fa-list
children:
# 此處省略其他菜單
- name: 壁紙
url: /wallpaper
icon: fas fa-image
- name: 相冊
url: /galleries
icon: fas fa-camera

在站點根目錄source下新建galleries目錄,然后在該目錄下新建index.md,就會生成index.html文件了

hexo new page "galleries"

修改/galleries/index.md文件, 指定布局界面:

---
title: 我的相冊
date: 2021-08-25 19:56:35
type: galleries
layout: galleries
---

添加相冊配置文件

在主題目錄下新建/source/_data/galleries.json文件, 按照自定義約定添加如下的相冊配置內容(我維護了三個相冊):

[
{ 

"name": "博客背景圖",
"url": "/gallery2",
"cover": "https://www.bing.com/th?id=OHR.Mpumalanga_ZH-CN9666962271_tmb.jpg&rf=",
"description": "博客背景圖",
"photos": [
"https://www.bing.com/th?id=OHR.Mpumalanga_ZH-CN9666962271_tmb.jpg&rf=",
]
},
{ 

"name": "彭于晏",
"url": "/gallery0",
"cover": "https://uploadfile.bizhizu.cn/2016/0106/20160106033828391.jpg",
"description": "彭于晏寫生",
"photos": [
"http://i.52desktop.cn:81/upimg/allimg/20191204/2019124151645578778013.jpg",
"http://i.52desktop.cn:81/upimg/allimg/20191204/2019124151645687778016.jpg"
]
},
{ 

"name": "劉德華",
"url": "/gallery1",
"cover": "https://tu1.whhost.net/uploads/20181029/18/1540809870-NgSCnhWkcJ.jpg",
"description": "劉德華寫生",
"photos": [
"https://uploadfile.bizhizu.cn/2015/0306/20150306103233272.jpg",
"https://www.beihaiting.com/uploads/allimg/150401/10723-150401195426203.jpg"
]
}
]

添加相冊布局文件

在主題目錄下新建/layout/galleries.ejs模板文件, 參照friends.ejs文件修改后內容如下:

<link rel="stylesheet" href="<%- theme.jsDelivr.url %><%- url_for(theme.libs.css.gallery) %>">
<%- partial('_partial/bg-cover') %>
<main class="content">
<div class="container">
<div class="title center-align" data-aos="zoom-in-up">
<i class="fas fa-camera"></i>&nbsp;&nbsp;<%- __('galleries') %>
</div>
<% if (site.data && site.data.galleries) { %>
<% var galleries = site.data.galleries; %>
<div class="gallery-wrapper row">
<% for (var i = 0, len = galleries.length; i < len; i++) { %>
<% var gallery = galleries[i]; %>
<div class="col s6 m4 l4 xl3 gallery-box">
<a href="./<%- gallery.url %>" class="gallery-item" data-aos="zoom-in-up">
<div class="gallery-cover-box">
</div>
<p class="gallery-name">
<%- gallery.name %>
</p>
</a>
</div>
<% } %>
</div>
<% } %>
</div>
</main>

相冊列表中的每個相冊都是一個<a></a>標簽, 點擊單個相冊會跳轉到相冊圖片展示頁面, 在主題目錄下新建/layout/gallery.ejs, 這里我們可以參考壁紙my-gallery.ejs文件的布局和渲染方式, 優化后的代碼如下:

<%- partial('_partial/bg-cover') %>
<%
var galleries = site.data.galleries;
var pageTitle = page.title;
var currentGallery = getCurrentGallery(galleries, pageTitle)
var photos = currentGallery.photos;
function getCurrentGallery(galleries, pageTitle) {
for (let i = 0; i < galleries.length; i++) {
if (galleries[i]['name'] == pageTitle) {
return galleries[i];
}
}
}
/***/
%>
<div id="myGallery" class="my-gallery">
<div class="title center-align" data-aos="zoom-in-up">
<p class="gallery-name">
<b><%- currentGallery.name %></b>
</p>
</div>
<div class="row">
<% if (photos) { %>
<% Object.keys(photos).forEach(function(photo) { %>
<div class="photo col s12 m6 l4" data-aos="fade-up">
<div class="img-item" data-src="<%- photos[photo] %>">
<img src="<%- theme.jsDelivr.url %><%- url_for(photos[photo]) %>" class="responsive-img">
</div>
</div>
<% }); %>
<% } %>
</div>
</div>
<script> $(function () { 
 let animateClass = 'animated pulse'; $('#myGallery .photo').hover(function () { 
 $(this).addClass(animateClass); }, function () { 
 $(this).removeClass(animateClass); }); }); </script>

添加相冊列表樣式

/layout/galleries.ejs模板文件模板引用了gallery.css樣式文件, 所以需要在主題目錄下新增/source/css/gallery.css文件, 添加內容如下:

.gallery-wrapper { 

padding-top: 30px;
}
.gallery-wrapper .gallery-box { 

padding: 5px !important;
}
.gallery-wrapper .gallery-item { 

display: block;
overflow: hidden;
background-color: #fff;
padding: 5px;
padding-bottom: 0;
position: relative;
-moz-box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.22);
-webkit-box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.22);
box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.22);
}
.gallery-cover-box { 

width: 100%;
padding-top: 60%;
text-align: center;
overflow: hidden;
position: relative;
background: center center no-repeat;
-webkit-background-size: cover;
background-size: cover;
}
.gallery-cover-box .gallery-cover-img { 

display: inline-block;
width: 100%;
position: absolute;
left: 50%;
top: 50%;
transform: translate(-50%, -50%);
}
.gallery-item .gallery-name { 

font-size: 14px;
line-height: 24px;
text-align: center;
color: #666;
margin: 0;
}
.waterfall { 

column-count: 3;
column-gap: 1em;
}
.photo-wrapper { 

padding-top: 20px;
}
.photo-item { 

display: block;
padding: 10px;
padding-bottom: 0;
margin-bottom: 14px;
font-size: 0;
-moz-page-break-inside: avoid;
-webkit-column-break-inside: avoid;
break-inside: avoid;
background: white;
-moz-box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.22);
-webkit-box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.22);
box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.22);
}
.photo-item img { 

width: 100%;
}
.photo-item .photo-name { 

font-size: 14px;
line-height: 30px;
text-align: center;
margin-top: 10px;
margin-bottom: 10px;
border-top: 1px solid #dddddd;
}
/*適配移動端布局*/
@media only screen and (max-width: 601px) { 

.waterfall { 

column-count: 2;
column-gap: 1em;
}
}

相冊列表效果

相冊展示效果

相冊密碼設置

給相冊設置密碼, 可以參考博客文章密碼訪問. 在主題目錄下的/layout/gallery.ejs文件中添加如下代碼:

<% if (theme.verifyPassword.enable) { 
 %>
<script src="<%- theme.jsDelivr.url %><%- url_for(theme.libs.js.crypto) %>"></script>
<script>
(function() { 

/*pwd是博客中配置的sha256加密后的密碼*/
let pwd = '<%- page.password %>';
if (pwd && pwd.length > 0) { 

if (pwd !== CryptoJS.SHA256(prompt('請輸入訪問本相冊的密
碼')).toString(CryptoJS.enc.Hex)) { 

alert('密碼錯誤!');
location.href = '<%- url_for("/galleries") %>';
}
}
})();
</script>
<% } %>

然后在需要設置密碼的gallery3相冊目錄下的/source/galleries/gallery3/index.md文件中設置password即可. 密碼需要使用SHA256加密.

36. 修改導航欄不透明

透明導航欄經常給我造成閱讀障礙,可以設置不使用透明導航欄, 指定好看的顏色. 找到主題目錄下的/source/css/matery.css 文件,修改如下部分:

header .nav-transparent { 

background-color: transparent !important;
/*background-color: #000B3F;*/  /*修改導航欄不透明 #16103f #4cbf30 #7371BC*/
background-image: none;
box-shadow: none;
}

37. 添加快捷導航

在博客根目錄下的\source\_posts\navigate\index.md目錄下新建快捷導航:

hexo new page navigate

修改主題目錄下的_config.yml文件, 添加快捷導航菜單:

## 快捷導航
menu:
// .... 此處省略其他菜單
Navigate:
url: /navigate
icon: fas fa-location-arrow

修改站點 /navigate/index.md文件

---
title: 快捷導航
date: 2021-08-29 16:25:05
layout: navigate
---

主題目錄下新建/layout/navigate.ejs文件,添加內容如下:

<div class="navi-height bg-cover pd-header">
<div class="link-box container">
<div class="baidu baidu-2 large-screen">
<form name="f" action="https://www.baidu.com/" target="_blank">
<div id="Select-2">
<div class="Select-box-2" id="baidu">
<ul>
<li class="this_s">百 度</li>
<li class="bing_s">必 應</li>
<li class="google_s">谷 歌</li>
<li class="baidu_s">百 度</li>
</ul>
</div>
<input name="wd" id="kw-2" maxlength="100" autocomplete="off" type="text">
</div>
<div class="qingkong" id="qingkong" title="清 · 空">x</div>
<input value="搜 索" id="su-2" type="submit"/>
<ul class="keylist"></ul>
</form>
</div>
<div class="row tags-posts">
<div class="col s12 m6 l4 friend-div" data-aos="zoom-in-up">
<div class="card">
<div class="jj-list-tit">編程 · 學習</div>
<ul class="jj-list-con">
<li>
<a  class="link-3" target="_blank">開源中國</a>
</li>
<li>
<a  class="link-3" target="_blank">HTML狗</a>
</li>
<li>
<a  class="link-3" target="_blank">中國大學慕課</a>
</li>
<li>
<a  class="link-3" target="_blank">慕課網</a>
</li>
<li>
<a  class="link-3" target="_blank">小程序</a>
</li>
<li>
<a  class="link-3" target="_blank">菜鳥教程</a>
</li>
<li>
<a  class="link-3" target="_blank">51CTO</a>
</li>
<li>
<a  class="link-3" target="_blank">實驗樓</a>
</li>
<li>
<a href="/posts/2d1a17c5.html" class="link-3" target="_blank">個人收藏頁</a>
</li>
</ul>
</div>
</div>
<div class="col s12 m6 l4 friend-div" data-aos="zoom-in-up">
<div class="card">
<div class="jj-list-tit">社區 · Code</div>
<ul class="jj-list-con">
<li>
<a  class="link-3" target="_blank">留言
</a>
</li>
<li>
<a  class="link-3" target="_blank">GitHub</a>
</li>
<li>
<a  class="link-3" target="_blank">Coding</a>
</li>
<li>
<a  class="link-3" target="_blank">掘金</a>
</li>
<li>
<a  class="link-3" target="_blank">碼云</a>
</li>
<li>
<a  class="link-3" target="_blank">CSDN</a>
</li>
<li>
<a  class="link-3" target="_blank">簡書</a>
</li>
<li>
<a  class="link-3" target="_blank">思否</a>
</li>
<li>
<a  class="link-3" target="_blank">云+社區
</a>
</li>
</ul>
</div>
</div>
<div class="col s12 m6 l4 friend-div" data-aos="zoom-in-up">
<div class="card">
<div class="jj-list-tit">實用 · 工具</div>
<ul class="jj-list-con">
<li>
<a  class="link-3" target="_blank">Nice編輯器</a>
</li>
<li>
<a  class="link-3" target="_blank">谷歌翻譯</a>
</li>
<li>
<a  class="link-3" target="_blank">在線PS</a>
</li>
<li>
<a  class="link-3" target="_blank">思維導圖</a>
</li>
<li>
<a  class="link-3" target="_blank">超清壁紙</a>
</li>
<li>
<a  class="link-3" target="_blank">二維碼</a>
</li>
<li>
<a  class="link-3" target="_blank">音范思</a>
</li>
<li>
<a  class="link-3" target="_blank">谷歌插件</a>
</li>
<li>
<a  class="link-3" target="_blank">OW分發</a>
</li>
</ul>
</div>
</div>
<div class="col s12 m6 l4 friend-div" data-aos="zoom-in-up">
<div class="card">
<div class="jj-list-tit">娛樂 · 影視</div>
<ul class="jj-list-con">
<li>
<a  class="link-3" target="_blank">京東</a>
</li>
<li>
<a  class="link-3" target="_blank">淘寶</a>
</li>
<li>
<a  class="link-3" target="_blank">天貓</a>
</li>
<li>
<a  class="link-3" target="_blank">騰訊視頻</a>
</li>
<li>
<a  class="link-3" target="_blank">愛奇藝</a>
</li>
<li>
<a  class="link-3" target="_blank">嗶哩嗶哩</a>
</li>
<li>
<a  class="link-3" target="_blank">網易云音樂</a>
</li>
<li>
<a  class="link-3" target="_blank">QQ音樂</a>
</li>
<li>
<a  class="link-3" target="_blank">酷狗音樂</a>
</li>
</ul>
</div>
</div>
<div class="col s12 m6 l4 friend-div" data-aos="zoom-in-up">
<div class="card">
<div class="jj-list-tit">資訊 · 趨勢</div>
<ul class="jj-list-con">
<li>
<a  class="link-3" target="_blank">虎嗅</a>
</li>
<li>
<a  class="link-3" target="_blank">技術調查
</a>
</li>
<li>
<a  class="link-3" target="_blank">摸魚</a>
</li>
<li>
<a  class="link-3" target="_blank">少數派</a>
</li>
<li>
<a  class="link-3" target="_blank">WikeHom</a>
</li>
<li>
<a  class="link-3" target="_blank">
前端趨勢
</a>
</li>
<li>
<a  class="link-3" target="_blank">GitHub趨勢</a>
</li>
<li>
<a  class="link-3" target="_blank">編程趨勢</a>
</li>
<li>
<a  class="link-3" target="_blank">Google趨勢</a>
</li>
</ul>
</div>
</div>
<div class="col s12 m6 l4 friend-div" data-aos="zoom-in-up">
<div class="card">
<div class="jj-list-tit">搜索 · 其他</div>
<ul class="jj-list-con">
<li>
<a  class="link-3" target="_blank">谷歌鏡像</a>
</li>
<li>
<a  class="link-3" target="_blank">網盤搜索</a>
</li>
<li>
<a  class="link-3" target="_blank">音樂搜索</a>
</li>
<li>
<a  class="link-3" target="_blank">電影天堂</a>
</li>
<li>
<a  class="link-3" target="_blank">代碼圖片</a>
</li>
<li>
<a  class="link-3" target="_blank">Boos</a>
</li>
<li>
<a  class="link-3" target="_blank">圖標庫</a>
</li>
<li>
<a  class="link-3" target="_blank">
在線工具
</a>
</li>
<li>
<a  class="link-3" target="_blank">中國色</a>
</li>
</ul>
</div>
</div>
</div>
<script> $(".Select-box ul").hover(function () { 
 $(this).css("height", "auto") }, function () { 
 $(this).css("height", "40px") }), $(".Select-box-2 ul").hover(function () { 
 $(this).css("height", "auto") }, function () { 
 $(this).css("height", "46px") }), $(".Select-box li").click(function () { 
 var t = $(this).attr("class"), s = $(this).html(); "baidu_s" == t && (t = "https://www.baidu.com/s", _name = "wd"), "google_s" == t && (t = "https://www.google.com/search", _name = "q"), "bing_s" == t && (t = "https://www.bing.com/search", _name = "q"), $(".baidu form").attr("action", t), $(".this_s").html(s), $("#kw").attr("name", _name), $(".Select-box ul").css("height", "40px") }), $(".Select-box-2 li").click(function () { 
 var t = $(this).attr("class"), s = $(this).html(); "baidu_s" == t && (t = "https://www.baidu.com/s", _name = "wd"), "google_s" == t && (t = "https://www.google.com/search", _name = "q"), "bing_s" == t && (t = "https://www.bing.com/search", _name = "q"), $(".baidu form").attr("action", t), $(".this_s").html(s), $("#kw-2").attr("name", _name), $(".Select-box-2 ul").css("height", "48px") }); $("#qingkong").click(function () { 
 $("input[ name='wd' ] ").val(""); }); let timer; function backgroundImgRandom() { 
 clearInterval(timer); timer = setInterval(function () { 
 // [0-9) $("body").css("background-image", "url(<%- theme.background.url[parseInt(Math.random() * 9)] %>"); }, 5000); } window.onload = backgroundImgRandom; </script>
</div>
</div>
<style> * { 
 margin: 0; padding: 0; font-family: consolas, hl, "微軟雅黑" } dd, dl, dt, form, h1, h2, h3, h4, h5, h6, li, p, ul { 
 margin: 0; padding: 0; font-size: 14px; font-weight: 400 } img { 
 border-style: none } li { 
 list-style: none; float: left } a { 
 text-decoration: none } .card { 
 background-color: rgba(25, 240, 229, 0); width: 96%; margin-left: 2% } .baidu { 
 float: left; margin-left: 100px } .baidu form { 
 position: relative } .Select-box ul { 
 height: 40px; position: absolute; left: -1px; top: 0; z-index: 9999; background: #FFF; border: 1px solid #ccc; border-top: none; overflow: hidden } .Select-box li { 
 width: 60px; line-height: 40px; font-size: 14px; color: #484848; border: 0; cursor: pointer } .Select-box li:hover { 
 background: #3385ff; color: #FFF } .Select-box .this_s { 
 color: #317ef3 } .Select-box .this_s:hover { 
 background: #FFF; color: #317ef3 } .qingkong { 
 position: absolute; right: 120px; top: 12px; width: 18px; height: 18px; background: rgba(0, 0, 0, .1); border-radius: 18px; line-height: 16px; color: #666; cursor: pointer; text-align: center; font-size: 14px; display: none; color: #881509; } .qingkong:hover { 
 background: rgba(0, 0, 0, .2) } .qingkong:active { 
 background: rgba(0, 0, 0, .3) } .baidu-2 { 
 width: 100%; height: 110px; margin: 0 auto; background: 0 0; padding-top: 50px } .baidu-2 form { 
 width: 520px; margin: 0 auto } .baidu-2 input { 
 padding: 13px 8px; opacity: .9; font-size: 15px } #Select-2 { 
 float: left } .Select-box-2 { 
 text-align: center; float: left; position: relative } .Select-box-2 ul { 
 height: 46px; position: absolute; left: 0; top: 1px; z-index: 9999; background: rgba(255, 255, 255, .9); border: 1px solid #ccc; border-top: none; overflow: hidden } .Select-box-2 li { 
 width: 60px; line-height: 46px; font-size: 15px; color: #484848; border: 0; cursor: pointer } .Select-box-2 li:hover { 
 background: #3385ff; color: #FFF } .Select-box-2 .this_s { 
 color: #317ef3 } .Select-box-2 .this_s:hover { 
 background: 0 0; color: #317ef3 } #kw-2 { 
 width: 335px; outline: 0; border: 1px solid #ccc; background: rgba(255, 255, 255, .2); color: #000; padding-left: 70px; font-weight: 700 } #su-2 { 
 width: 90px; background: #4e6ef2; border: none; border-top: #3385ff 1px solid; border-bottom: 1px solid #2d78f4; color: #FFF; cursor: pointer; outline: 0 } #su-2:hover { 
 background: #00f; border-bottom: 1px solid #00f } #su-2:active { 
 background: #00f; box-shadow: inset 1px 1px 3px #00f; -webkit-box-shadow: inset 1px 1px 3px #00f } #su-3 { 
 width: 90px; background: #00f; border: none; border-top: #3385ff 1px solid; border-bottom: 1px solid #2d78f4; color: #FFF; cursor: pointer; outline: 0 } .jj-list-tit { 
 font-size: 16px; line-height: 25px; color: #fff; width: 100%; padding-left: 38.5% } .jj-list-con { 
 overflow: hidden; margin: 0 auto } .jj-list-con li { 
 width: 31.333%; margin: 1% } .link-3 { 
 display: block; background: rgba(0, 0, 0, .35); color: #FFF; font-size: 13px; text-align: center; line-height: 35px; padding: 4px 0; border-radius: 2px; transition: all .2s } .link-3:hover { 
 background: rgba(0, 0, 0, .45); font-size: 15px; font-weight: 700 } @media only screen and (max-width: 584px) { 
 .navi-height { 
 height: 1300px } .link-box { 
 margin-top: 5% } .large-screen { 
 display: none } } @media only screen and (min-width: 584px) and (max-width: 993px) { 
 .navi-height { 
 height: 800px } .link-box { 
 margin-top: 5% } .large-screen { 
 display: none } } @media only screen and (min-width: 993px) { 
 .navi-height { 
 position: absolute; width: 100%; height: 100% } } .page-footer { 
 display: none } </style>

主題目錄下的/layout/_partial/navigation.ejs文件添加快捷導航菜單中文名稱. 以及移動客戶端文件/layout/_partial/mobile-nav.ejs一樣添加.

<%
var menuMap = new Map();
menuMap.set("Index", "首頁");
menuMap.set("Tags", "標簽");
menuMap.set("Categories", "分類");
menuMap.set("Archives", "歸檔");
menuMap.set("About", "關于");
menuMap.set("Contact", "留言板");
menuMap.set("Friends", "友情鏈接");
menuMap.set("Lists", "清單");
menuMap.set("Navigate", "快捷導航");
var configRoot = config.root
configRoot = (configRoot === null || configRoot === undefined 
|| configRoot === '/') ? '' : configRoot;
%>

38. 添加音樂導航頁

在博客根目錄下新增\source\_posts\musics\index.md文件

hexo new page musics

主題目錄下的_config.yml文件中添加[清單-音樂]菜單:

menu:
// 此處省略其他菜單項
Lists:  ##清單
url: /
icon: fas fa-list
children:
- name: 音樂
url: /musics
icon: fas fa-music

修改音樂文件/musics/index.md指定布局配置:

---
title: musics
date: 2021-08-25 19:55:53
layout: musics
---

主題目錄下新增音樂布局文件 /layout/musics.ejs, 添加如下內容:

<style type="text/css"> /* don't remove. */ .about-cover { 
 height: 75vh; } </style>
<%- partial('_partial/bg-cover') %>
<main class="content">
<% if (theme.mymusic.enable) { %>
<%- partial('_widget/mymusic') %>
<% } %>
</main>

主題目錄下新增自定義音樂播放器文件 /layout/_widget/mymusic.ejs, 添加如下內容:

<link rel="stylesheet" href="<%- theme.jsDelivr.url %><%- url_for(theme.libs.css.aplayer) %>">
<style> .aplayer .aplayer-lrc p { 
 <%if(theme.mymusic.hideLrc){ 
%> display: none; <%}%> font-size: 12px; font-weight: 700; line-height: 16px !important; } .aplayer .aplayer-lrc p.aplayer-lrc-current { 
 <%if(theme.mymusic.hideLrc){ 
%> display: none; <%}%> font-size: 15px; color: <%- theme.mymusic.theme %>; } <%if(theme.mymusic.autoHide){ 
%> .aplayer.aplayer-fixed.aplayer-narrow .aplayer-body { 
 left: -66px !important; } .aplayer.aplayer-fixed.aplayer-narrow .aplayer-body:hover { 
 left: 0px !important; } <%}%> </style>
<div class="<% if(!theme.mymusic.fixed) { %>music-player<% } %>">
<% if (!theme.mymusic.fixed && theme.mymusic.title.enable) { %>
<div class="title center-align">
<i class="fas fa-music"></i>&nbsp;&nbsp;<%- theme.mymusic.title.show %>
</div>
<% } %>
<div class="row">
<meting-js class="col l8 offset-l2 m10 offset-m1 s12" server="<%- theme.mymusic.server %>" type="<%- theme.mymusic.type %>" id="<%- theme.mymusic.id %>" fixed='<%- theme.mymusic.fixed ? 'true' : 'false' %>'
autoplay='<%- theme.mymusic.autoplay === true %>'
theme='<%- theme.mymusic.theme %>'
loop='<%- theme.mymusic.loop %>'
order='<%- theme.mymusic.order %>'
preload='<%- theme.mymusic.preload %>'
volume='<%- Number(theme.mymusic.volume) %>'
list-folded='<%- theme.mymusic.listFolded ? 'true' : 'false' %>'
>
</meting-js>
</div>
</div>
<script src="<%- theme.jsDelivr.url %><%- url_for(theme.libs.js.aplayer) %>"></script>
<script src="https://cdn.jsdelivr.net/npm/meting@2/dist/Meting.min.js"></script>

主題目錄下配置文件_config.yml添加自定義音樂播放器配置:

# 自定義音樂組件, 展示在自己需要的頁面
mymusic:
enable: true
title: #非吸底模式有效
enable: true
show: 輕松時刻
autoHide: true    # hide automaticaly
server: netease   #require music platform: netease, tencent, kugou, xiami, baidu
type: playlist    #require song, playlist, album, search, artist
id: 4965675848     #require song id / playlist id (useful playlist 4965675848 2888085740)/ album id / search keyword
fixed: false       # 開啟吸底模式 true 播放器會在站點側邊,點擊會出現
autoplay: false   # 是否自動播放
theme: '#42b983'
loop: 'all'       # 音頻循環播放, 可選值: 'all', 'one', 'none'
order: 'random'   # 音頻循環順序, 可選值: 'list', 'random'
preload: 'auto'   # 預加載,可選值: 'none', 'metadata', 'auto'
volume: 0.7       # 默認音量,請注意播放器會記憶用戶設置,用戶手動設置音量后默認音量即失效
listFolded: false  # 列表默認折疊
hideLrc: false     # 隱藏歌詞

39. 生成電影卡片

安裝hexo-tag-mtime插件

npm install hexo-tag-mtime --save

新增電影導航頁面, 博客根目錄下生成/source/movies/index.md文件:

hexo new page movies

/source/movies/index.md文件添加如下內容:

---
title: 電影推薦
date: 2021-08-25 19:56:04
type: movies
---
## 精彩電影推薦
###  怒火·重案
{% mtime 263501 %}
###  再見,少年
{% mtime 259370 %}
### 流浪地球
{% mtime 218707 %}
id可以在時光網 https://www.mtime.com 相應的電影網址獲取

40. 添加夜間模式切換

在主題目錄下的/layout/layout.ejs文件添加夜間模式切換按鈕:

<!-- 切換夜間/白天模式按鈕 -->
<a onclick="switchNightMode()" id="sma"> <i class="fa fa-moon-o" id="nightMode" aria-hidden="true"></i> </a>

在主題目錄下的/source/js/matery.js文件添加js代碼:

// 深色模式按鈕設置
if (localStorage.getItem('dark') === '1') { 

document.body.classList.add('dark');
} else if (new Date().getHours() >= 22 || new Date().getHours() < 7) { 

/*定時開啟暗色模式<默認晚22點至早6點默認開啟>*/
// document.body.classList.add('dark');
// $("#nightMode").removeClass("fa-moon-o").addClass("fa-lightbulb");
} else if (matchMedia('(prefers-color-scheme: dark)').matches) { 

document.body.classList.add('dark');
}
// 深色模式設置
function switchNightMode() { 

var body = document.body;
if (body.classList.contains('dark')) { 

document.body.classList.remove('dark');
localStorage.setItem('dark', '0');
$('#nightMode').removeClass("fa-lightbulb").addClass("fa-moon-o");
return;
} else { 

document.body.classList.add('dark');
localStorage.setItem('dark', '1');
$('#nightMode').removeClass("fa-moon-o").addClass("fa-lightbulb");
return;
}
}
/*提醒開啟夜間模式功能*/
setTimeout(
function () { 

if ((new Date().getHours() >= 19 || new Date().getHours() < 7) && !$('body').hasClass('DarkMode')) { 

let toastHTML = '<span token operator">+ '<i class="fa fa-bell" aria-hidden="true"></i>晚上使用深色模式閱讀更好哦。(?▽?)/</span>'
M.toast({ 
html: toastHTML})
}
}, 2200);

在主題目錄下的/source/css/matery.css文件添加夜間模式切換的樣式:

/******夜間模式切換樣式 start*******/
/* 深色模式按鈕設置 */
#sma { 

background: #000;
width: 38px;
height: 38px;
display: block;
position: fixed;
border-radius: 50%;
right: 15px;
bottom: 170px;
padding-top: 15px;
margin-bottom: 0;
z-index: 998;
cursor: pointer;
}
#sma .fa-moon-o { 

position: absolute;
right: 8px;
bottom: 8px;
font-size: 1.48rem !important;
}
#sma .fa-lightbulb { 

position: absolute;
right: 13px;
bottom: 8px;
font-size: 1.5rem !important;
}
.fa-moon-o:before { 

content: "\f186";
}
.fa-comments:before { 

content: "\f086";
}
/* 深色模式設置 */ /* 字體顏色變灰白色 */
body.dark .fas, body.dark .title, body.dark .row .text, body.dark article .article-content .summary, body.dark .card .card-image .card-title, body.dark .fa-moon-o:before, body.dark .fa-lightbulb:before, body.dark article .article-tags .chip, body.dark .chip-container .tag-title, body.dark div.jqcloud a, body.dark .friends-container .tag-title, body.dark .frind-ship .title h1, body.dark .card .card-content p, body.dark .v[data-class=v] .vcount, body.dark .v[data-class=v] .vcount .vnum, body.dark pre code, body.dark h1, body.dark h2, body.dark h3, body.dark h4, body.dark h5, body.dark h6, body.dark li, body.dark p, body.dark header .side-nav .mobile-head .logo-name, body.dark header .side-nav .mobile-head .logo-desc, body.dark header .side-nav .menu-list a, body.dark .bg-cover .post-title, body.dark a { 

color: rgba(255, 255, 255, 0.6);
}
/* 背景顏色變灰色 */
body.dark .card, body.dark .block-with-text:after { 

background-color: #282c34;
}
/* 背景顏色變黑色 */
body.dark, body.dark .v[data-class=v] .vcount, body.dark #rewardModal .modal-content, body.dark .modal, body.dark header .side-nav, body.dark header .side-nav .menu-list .m-nav-show { 

background-color: #12121c;
/**因為我的背景圖導致部分頁面無法全部切換成深色背景, 需要取消背景圖片**/
background-image: url(#); 
}
/* 改變透明度 */
body.dark .aplayer { 

background: #2f3742 !important;
}
body.dark img, body.dark strong { 

filter: brightness(.7);
}
/******夜間模式切換樣式 end*******/

41. 添加valine評論功能

使用valine評論功能, 可以使用leanCloud國際版存儲評論數據, 具體申請ID和KEY的教程如下:

文字教程: https://cndrew.cn/2020/04/10/hexo-shuoshuo/

B站視頻: https://www.bilibili.com/video/BV16A411b7UF

在主題目錄下創建/layout/_partial/valine.ejs文件, 添加如下內容:

<style> .valine-card { 
 margin: 1.5rem auto; } .valine-card .card-content { 
 padding: 20px 20px 5px 20px; } #vcomments textarea { 
 box-sizing: border-box; background: url("<%- url_for(theme.valine.background) %>") 100% 100% no-repeat; } #vcomments p { 
 margin: 2px 2px 10px; font-size: 1.05rem; line-height: 1.78rem; } #vcomments blockquote p { 
 text-indent: 0.2rem; } #vcomments a { 
 padding: 0 2px; color: #4cbf30; font-weight: 500; text-decoration: none; } #vcomments img { 
 max-width: 100%; height: auto; cursor: pointer; } #vcomments ol li { 
 list-style-type: decimal; } #vcomments ol, ul { 
 display: block; padding-left: 2em; word-spacing: 0.05rem; } #vcomments ul li, ol li { 
 display: list-item; line-height: 1.8rem; font-size: 1rem; } #vcomments ul li { 
 list-style-type: disc; } #vcomments ul ul li { 
 list-style-type: circle; } #vcomments table, th, td { 
 padding: 12px 13px; border: 1px solid #dfe2e5; } #vcomments table, th, td { 
 border: 0; } table tr:nth-child(2n), thead { 
 background-color: #fafafa; } #vcomments table th { 
 background-color: #f2f2f2; min-width: 80px; } #vcomments table td { 
 min-width: 80px; } #vcomments h1 { 
 font-size: 1.85rem; font-weight: bold; line-height: 2.2rem; } #vcomments h2 { 
 font-size: 1.65rem; font-weight: bold; line-height: 1.9rem; } #vcomments h3 { 
 font-size: 1.45rem; font-weight: bold; line-height: 1.7rem; } #vcomments h4 { 
 font-size: 1.25rem; font-weight: bold; line-height: 1.5rem; } #vcomments h5 { 
 font-size: 1.1rem; font-weight: bold; line-height: 1.4rem; } #vcomments h6 { 
 font-size: 1rem; line-height: 1.3rem; } #vcomments p { 
 font-size: 1rem; line-height: 1.5rem; } #vcomments hr { 
 margin: 12px 0; border: 0; border-top: 1px solid #ccc; } #vcomments blockquote { 
 margin: 15px 0; border-left: 5px solid #42b983; padding: 1rem 0.8rem 0.3rem 0.8rem; color: #666; background-color: rgba(66, 185, 131, .1); } #vcomments pre { 
 font-family: monospace, monospace; padding: 1.2em; margin: .5em 0; background: #272822; overflow: auto; border-radius: 0.3em; tab-size: 4; } #vcomments code { 
 font-family: monospace, monospace; padding: 1px 3px; font-size: 0.92rem; color: #e96900; background-color: #f8f8f8; border-radius: 2px; } #vcomments pre code { 
 font-family: monospace, monospace; padding: 0; color: #e8eaf6; background-color: #272822; } #vcomments pre[class*="language-"] { 
 padding: 1.2em; margin: .5em 0; } #vcomments code[class*="language-"], pre[class*="language-"] { 
 color: #e8eaf6; } #vcomments [type="checkbox"]:not(:checked), [type="checkbox"]:checked { 
 position: inherit; margin-left: -1.3rem; margin-right: 0.4rem; margin-top: -1px; vertical-align: middle; left: unset; visibility: visible; } #vcomments b, strong { 
 font-weight: bold; } #vcomments dfn { 
 font-style: italic; } #vcomments small { 
 font-size: 85%; } #vcomments cite { 
 font-style: normal; } #vcomments mark { 
 background-color: #fcf8e3; padding: .2em; } #vcomments table, th, td { 
 padding: 12px 13px; border: 1px solid #dfe2e5; } table tr:nth-child(2n), thead { 
 background-color: #fafafa; } #vcomments table th { 
 background-color: #f2f2f2; min-width: 80px; } #vcomments table td { 
 min-width: 80px; } #vcomments [type="checkbox"]:not(:checked), [type="checkbox"]:checked { 
 position: inherit; margin-left: -1.3rem; margin-right: 0.4rem; margin-top: -1px; vertical-align: middle; left: unset; visibility: visible; } .v[data-class="v"] .vwrap .vheader .vinput { 
 width: 32%; border-bottom: 1px dashed #dedede; } </style>
<div class="card valine-card" data-aos="fade-up">
<div class="comment_headling">
<i class="fas fa-comments fa-fw" aria-hidden="true"></i>
<span>評論</span>
</div>
<div id="vcomments" class="card-content">
</div>
</div>
<script src="<%- theme.jsDelivr.url %><%- url_for('/libs/valine/av-min.js') %>"></script>
<script src="<%- theme.jsDelivr.url %><%- url_for(theme.libs.js.valine) %>"></script>
<script> let metaPlaceholder = <%- JSON.stringify(theme.valine.metaPlaceholder) %> ; //這里要換行 new Valine({ 
 el: '#vcomments', appId: '<%- theme.valine.appId %>', appKey: '<%- theme.valine.appKey %>', notify: '<%- theme.valine.notify %>' === 'true', verify: '<%- theme.valine.verify %>' === 'true', visitor: '<%- theme.valine.visitor %>' === 'true', avatar: '<%- theme.valine.avatar %>', pageSize: '<%- theme.valine.pageSize %>', lang: '<%- theme.valine.lang %>', placeholder: '<%= theme.valine.placeholder %>', meta: <%- '["' + theme.valine.guest_info.join('", "') + '"]' %>, recordIP: '<%- theme.valine.recordIP %>' === 'true', enableQQ: '<%- theme.valine.avatar %>', requiredFields: <%- '["' + theme.valine.guest_info.join('", "') + '"]' %>, master: <%- '["' + theme.valine.master.join('", "') + '"]' %>, friends: <%- '["' + theme.valine.friends.join('", "') + '"]' %>, tagMeta: <%- '["' + theme.valine.tagMeta.join('", "') + '"]' %>, metaPlaceholder: metaPlaceholder, }); document.body.addEventListener('click', function (e) { 
 if (e.target.classList.contains('vsubmit')) { 
 const email = document.querySelector('input[type=email]'); const nick = document.querySelector('input[name=nick]'); const reg = /^[A-Za-z0-9_-\u4e00-\u9fa5]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/; if (!email.value || !nick.value || !reg.test(email.value)) { 
 const str = `<div class="valert txt-center"><div class="vtext">請填寫正確的昵稱和郵箱!</div></div>`; const vmark = document.querySelector('.vmark'); vmark.innerHTML = str; vmark.style.display = 'block'; e.stopPropagation(); setTimeout(function () { 
 vmark.style.display = 'none'; vmark.innerHTML = ''; }, 2500); } } }, true); </script>

然后在需要評論功能的頁面引用valine.ejs, 我的在留言版博客文章中添加了評論功能, 分別是主題目錄下的/layout/contact.ejs/layout/_partial/post-detail.ejs文件添加如下內容:

<% if (theme.valine && theme.valine.enable) { %>
<%- partial('_partial/valine') %>
<% } %>

然后在主題目錄下的_config.yml文件中啟用valine評論功能, 并添加一部分valine.ejs中用到的自定義屬性.

# Valine 評論模塊的配置,默認為不激活,如要使用,就請激活該配置項,并設置 appId 和 appKey.
valine:
enable: true
appId: NiVMV7aR8ipVDy9EywBYtLwI-MdYXbMMI
appKey: P7BGA1hMeBAFbHYz3dKY8doJ
notify: false # 是否開啟郵件提醒(https://valine.js.org/notify.html)
verify: true # 是否啟用防垃圾驗證
visitor: true
avatar: monsterid # 默認頭像展示方式,小怪物 # 'mm' # Gravatar style : mm/identicon/monsterid/wavatar/retro/hide
pageSize: 10
placeholder: '填寫QQ號就能評論,快來一發吧~'  # Comment Box placeholder
/medias/comment_bg.png #背景圖
background: https://cdn.jsdelivr.net/gh/drew233/cdn/20200409110727.webp 
coolpushkey:
# 新增屬性 wang-qz
comment_count: true
enableQQ: true  # 強制QQ
recordIP: true
requiredFields: # 必須輸入的信息,默認 [昵稱, 郵箱, link]
- nick
- mail
guest_info: # 評論框展示的輸入項, 默認[nick, mail, link], 可以設置不填某些選項
- nick
- mail
- link
master:
- e4de1f6da602d22e423d6dfb24611b6b  # md5加密后的博主郵箱 wang-qz@foxmail.com
metaPlaceholder:  # 輸入框的背景文字
nick: 昵稱/QQ號(必填)
mail: 郵箱(必填)
link: 網址(https://)
lang: zh-CN
tagMeta: # 評論標簽要顯示的文字
- 博主
- 小伙伴
- 訪客
friends: # md5 加密后的小伙伴郵箱
- 410739a5ad278251b305dab085768c57 # 1848276756@qq.com
- 410739a5ad278251b305dab085768c57
- 410739a5ad278251b305dab085768c57

另外, valine.min.js 需要進行升級, 我使用的版本是 valine-1.4版本:

<script src="https://cdn.jsdelivr.net/gh/small-rose/small-rose.github.io/libs/valine/Valine.min.js"></script>

因為上面“valine.ejs文件中是引用的/lib/js/valine/valine.min.js`, 所以也可以下載下來替換該js文件.

下面這個版本也可以, 去gitHub克隆下來, 然后使用他的valine.min.js替換本地的即可.

https://github.com/LuckyZmj/LuckyBlog/blob/master/themes/matery/source/libs/valine/Valine.min.js

valine.ejs文件中是引用valine.min.js的方式需要在主題目錄下的_config.yml文件中搜索關鍵詞 libs, 找到 js , 在js引用配置的最后一行然后添加:

valine: /libs/valine/Valine.min.js 

這樣下面的引用方式就能找到/lib/js/valine/valine.min.js文件

<script src="<%- theme.jsDelivr.url %><%- url_for(theme.libs.js.valine) %>"></script>

42. 添加artitalk說說功能

參考資料: Hexo博客Matery主題添加ArtiTalk說說模塊

具體使用見artitalk官方文檔 , 發布說說的數據可以存儲在LeanCloud, 上面評論功能已經提供了相關使用參考資料.

首先, 下載artitalk源碼

git clone git@github.com:ArtitalkJS/Artitalk.git

在主題目錄下新建/source/libs/artitalk文件夾, 找到剛才下載artitalk源碼,進入dist 目錄,里面有2個文件夾:css 和 js, 然后進行如下操作:

/Artitalk/dist/css/ 下的 artitalk.min.css 復制到主題目錄 /source/libs/artitalk下;

/Artitalk/dist/js/下的 artitalk.min.js 復制到主題目錄 /source/libs/artitalk下;
因為要和matery主題引入風格保持一致, 修改主題配置_config.yml文件, 搜索關鍵詞libs,

找到css在最后一行添加:

artitalk: /libs/artitalk/artitalk.min.css

找到js, 在最后一行添加:

artitalk: /libs/artitalk/artitalk.min.js

我列一下最終效果,因為原來有很多,我就不全部列出了,只要知道最后一行加就可以了,注意對齊,如下:

libs:
css:
fontAwesome: /libs/awesome/css/all.css # V5.11.1
materialize: /libs/materialize/materialize.min.css # 1.0.0
artitalk: /libs/artitalk/artitalk.min.css # 最后一行添加
js:
jquery: /libs/jquery/jquery.min.js
materialize: /libs/materialize/materialize.min.js # 1.0.0
artitalk: /libs/artitalk/artitalk.min.js  # 最后一行添加

找到主題目錄下 /layout/_partial/head.ejs,在頭部引入css:

<link rel="stylesheet" type="text/css" href="<%- theme.jsDelivr.url %><%- url_for(theme.libs.css.artitalk) %>">

模塊準備, 在主題目錄下新建一個/layout/artitalk.ejs文件, 添加如下內容:

<style type="text/css"> /* don't remove. */ .about-cover { 
 height: 75vh; } </style>
<%- partial('_partial/bg-cover') %>
<main class="content">
<% if (theme.artitalk && theme.artitalk.enable) { %>
<%- partial('_widget/artitalk') %>
<% } %>
</main>

在主題目錄下新建一個/layout/_widget/artitalk.ejs文件, 在上面代碼中已經引入了該文件, 文件的內容如下:

<style type="text/css"> #artitalk_main .cbp_tmtimeline > li .cbp_tmlabel::after { 
 right: 100%; border: solid transparent; z-index: -1; content: " "; height: 0; width: 0; position: absolute; pointer-events: none; border-right-color: #0bb7fbd6 ; border-width: 10px; top: 4px; } #pubShuo { 
 margin-right: 5px; } #operare_artitalk .shuoshuo_input_log { 
 outline-style: none; margin-top: 5px; border: 1px solid #ccc; border-radius: 6px; padding: 8px 16px; font-size: 12px; background-color: transparent; color: #0bb7fbd6; width: 70%; height: 28px; margin-left: 10px; } #artitalk_main { 
 margin-top: 5px; margin-left: 5%; margin-right: 5%; } #lazy { 
 margin-top: 40px; } </style>
<script src="<%- theme.jsDelivr.url %><%- url_for(theme.libs.js.artitalk) %>"></script>
<article id="articles11" class="container chip-container">
<div class="row ">
<div class=" card">
<div class="card-content">
<div class="tag-title center-align">
<i class="fas fa-pen-alt"></i> 說說
</div>
<div id="artitalk_main"></div>
</div>
</div>
</div>
</article>
<script> new Artitalk({ 
 appId: "<%= theme.artitalk.appId %>", appKey: "<%= theme.artitalk.appKey %>", <% if (theme.artitalk.serverURL) { 
 %> serverURL: "<%= theme.artitalk.serverURL %>", <% } %> <% if (theme.artitalk.lang) { 
 %> lang: "<%= theme.artitalk.lang %>", <% } %> <% if (theme.artitalk.pageSize) { 
 %> pageSize: "<%= theme.artitalk.pageSize %>", <% } %> <% if (theme.artitalk.shuoPla) { 
 %> shuoPla: "<%= theme.artitalk.shuoPla %>", <% } %> <% if (theme.artitalk.avatarPla) { 
 %> avatarPla: "<%= theme.artitalk.avatarPla %>", <% } %> <% if (theme.artitalk.motion == 0) { 
 %> motion: 0, <% } else { 
 %> motion: 1, <% } %> <% if (theme.artitalk.bgImg) { 
 %> bgImg: "<%= theme.artitalk.bgImg %>", <% } %> <% if (theme.artitalk.color1) { 
 %> color1: "<%= theme.artitalk.color1 %>", <% } %> <% if (theme.artitalk.color2) { 
 %> color2: "<%= theme.artitalk.color2 %>", <% } %> <% if (theme.artitalk.color3) { 
 %> color3: "<%= theme.artitalk.color3 %>", <% } %> <% if (theme.artitalk.cssUrl) { 
 %> cssUrl: "<%= theme.artitalk.cssUrl %>", <% } %> atEmoji: { 
 baiyan: "https://cdn.jsdelivr.net/gh/Artitalk/Artitalk-emoji/baiyan.png", bishi: "https://cdn.jsdelivr.net/gh/Artitalk/Artitalk-emoji/bishi.png", bizui: "https://cdn.jsdelivr.net/gh/Artitalk/Artitalk-emoji/bizui.png", chan: "https://cdn.jsdelivr.net/gh/Artitalk/Artitalk-emoji/chan.png", daku: "https://cdn.jsdelivr.net/gh/Artitalk/Artitalk-emoji/daku.png", dalao: "https://cdn.jsdelivr.net/gh/Artitalk/Artitalk-emoji/dalao.png", dalian: "https://cdn.jsdelivr.net/gh/Artitalk/Artitalk-emoji/dalian.png", dianzan: "https://cdn.jsdelivr.net/gh/Artitalk/Artitalk-emoji/dianzan.png", doge: "https://cdn.jsdelivr.net/gh/Artitalk/Artitalk-emoji/doge.png", facai: "https://cdn.jsdelivr.net/gh/Artitalk/Artitalk-emoji/facai.png", fadai: "https://cdn.jsdelivr.net/gh/Artitalk/Artitalk-emoji/fadai.png", fanu: "https://cdn.jsdelivr.net/gh/Artitalk/Artitalk-emoji/fanu.png", }, }) </script>

在主題目錄下的_config.yml文件中添加如下配置:

# 說說 https://artitalk.js.org/
artitalk:
enable: true
appId: NiVMV7aR8ipVDy9EywBYtLwI-MdYXbMMI # leancloud的應用appId
appKey: P7BGA1hMeBAFbHYz3dKY8doJ # leancloud的應用appKey
serverURL: # #leancloud綁定的安全域名,使用國際版的話不需要填寫
lang: zh # 語言設置,zh為漢語,en為英語,es為西班牙語。默認為漢語
pageSize: 6 # 每頁顯示說說的數量
shuoPla: '只有王子才能發布說說哦' # 在編輯說說的輸入框中的占位符
motion: 1 #加載動畫的開關,1為開,0為關,默認為開
#說說輸入框背景圖片url
bgImg: https://cdn.jsdelivr.net/gh/drew233/cdn/20200409110727.webp 
avatarPla: https://cdn.jsdelivr.net/gh/small-rose/small-rose.github.io/medias/avatar.jpg #自定義頭像url的輸入框的占位符
color1: linear-gradient(45deg, rgb(109, 208, 242) 15%, rgb(245, 154, 190) 85%) #說說背景顏色1&按鈕顏色1
color2: linear-gradient(45deg, rgb(109, 208, 242) 15%, rgb(245, 154, 190) 85%) #說說背景顏色2&按鈕顏色2
color3: black #說說字體顏色

更多配置項參考官網:配置項說明

最后創建頁面, 手工創建或者執行hexo命令創建都可以.

hexo new page "artitalk"

在 hexo 的 source 目錄會生成一個 artitalk 文件夾,修改里面的 index.md :

---
title: artitalk
date: 2021-09-03 20:31:58
type: artitalk
layout: artitalk
---

主題目錄下的_config.yml文件配置菜單:

menu:
##關于
About:
url: /crystal-blog
icon: fas fa-rocket
children:
- name: 關于我
url: /about
icon: fas fa-user-circle
- name: artitalk
url: /artitalk
icon: fas fa-pen-alt

配色參考: https://colordrop.io/

43. 歸檔時間軸添加時間列表的切換

歸檔的布局文件是主題目錄下的/layout/archive.ejs, 原來里面的邏輯是以卡片的形式循環展示所有的博客文章. 具體代碼如下:

 <!--時間軸區域塊-->
<div id="cd-timeline" class="container">
<% page.posts.each(function(post) { %>
<div class="cd-timeline-block">
<%# year. %>
<% if (date(post.date, 'YYYY') != year) { %>
<% year = date(post.date, 'YYYY'); %>
<div class="cd-timeline-img year" data-aos="zoom-in-up">
<a href="<%- url_for('/archives/' + year) %>"><%- year %></a>
</div>
<% } %>
<%# month. %>
<% if (date(post.date, 'YYYY-MM') != month) { %>
<%
month = date(post.date, 'YYYY-MM');
var m = date(post.date, 'MM')
%>
<div class="cd-timeline-img month" data-aos="zoom-in-up">
<a href="<%- url_for('/archives/' + year + '/' + m) %>">
<%- m %></a>
</div>
<% } %>
<%# every day posts. %>
<div class="cd-timeline-img day" data-aos="zoom-in-up">
<span><%- date(post.date, 'YYYY-MM-DD').substring(8, 10) %></span>
</div>
<article class="cd-timeline-content" data-aos="fade-up">
<div class="article col s12 m6">
<div class="card">
<a href="<%- url_for(post.path) %>">
<div class="card-image">
<% if (post.img) { %>
<img src="<%- url_for(post.img) %>" class="responsive-img" alt="<%= post.title %>">
<% } else { %>
<%
featureimg =                                           featureImages[Math.abs(hashCode(post.title) 
% featureImages.length)];
%>
<img src="<%- theme.jsDelivr.url %> <%- url_for(featureimg) %>" class="responsive-img" alt="<%= post.title %>">
<% } %>
<span class="card-title"><%= post.title %>
</span>
</div>
</a>
<div class="card-content article-content">
<div class="summary block-with-text">
<% if (post.summary && post.summary.length > 0)
{ %>
<%- post.summary %>
<% } else { %>
<%- strip_html(post.content).substring(0, 
120) %>
<% } %>
</div>
<div class="publish-info">
<span class="publish-date">
<i class="far fa-clock fa-fw icon-date"></i>
<%= date(post.date, config.date_format) %>
</span>
<span class="publish-author">
<% if (post.categories && 
post.categories.length > 0) { %>
<i class="fas fa-bookmark fa-fw icon-category"></i>
<% post.categories.forEach(category => { 
%>
<a href="<%- url_for(category.path) %>" class="post-category">
<%- category.name %>
</a>
<% }); %>
<% } else if (post.author && 
post.author.length > 0) { %>
<i class="fas fa-user fa-fw"></i>
<%- post.author %>
<% } else { %>
<i class="fas fa-user fa-fw"></i>
<%- config.author %>
<% } %>
</span>
</div>
</div>
<% if (post.tags && post.tags.length) { %>
<div class="card-action article-tags">
<% post.tags.forEach(tag => { %>
<a href="<%- url_for(tag.path) %>">
<span class="chip bg-color">
<%= tag.name %></span></a>
<% }); %>
</div>
<% } %>
</div>
</div>
</article>
</div>
<% }); %>
</div>

我看到網上有些博客的歸檔是以時間列表方式展現的, 這樣對所有博客文章有更佳的查看體驗. 于是通過debug模式將網上大佬的博客效果代碼copy下來, 再經過自己的修改后, 達到了想要的效果. 下面操作.

先添加時間列表時間軸的切換按鈕, 在主題目錄下的/layout/archive.ejs文件中添加如下代碼:

<div class="container">
<div class="card">
<div class="card-content">
<div class="tag-chips">
<span onclick="showTable()" id="sp-table" class="chip center-align waves-effect waves-light default" data-tagname="時間列表">時間列表
</span>
<span onclick="showTime()" id="sp-timeline" class="chip center-align waves-effect waves-light default" data-tagname="時間軸">時間軸
</span>
</div>
</div>
</div>
</div>

實現切換效果的js代碼:

<script>
function showTime() { 

$("#cd-timeline").show();
$("#cd-table").hide();
$("#sp-timeline").css('background', 'linear-gradient(to right, #4cbf30 0%, 
#0f9d58 100%)');
$("#sp-timeline").css('color', '#fff');
$("#sp-table").css('background', '#F9EBEA')
$("#sp-table").css('color', 'rgba(0,0,0,0.6)');
}
function showTable() { 

$("#cd-timeline").hide();
$("#cd-table").show();
$("#sp-table").css('background', 'linear-gradient(to right, #4cbf30 0%, 
#0f9d58 100%)');
$("#sp-table").css('color', '#fff');
$("#sp-timeline").css('background', '#F9EBEA')
$("#sp-timeline").css('color', 'rgba(0,0,0,0.6)');
}
</script>

切換到時間列表的代碼:

<div id="cd-table" class="container archive-container">
<% page.posts.each(function(post) { %>
<div class="card">
<div class="card-content">
<div class="archive">
<%# year. %>
<% if (date(post.date, 'YYYY') != year) { %>
<% year = date(post.date, 'YYYY'); %>
<h4 class="archive-year" id="<%- year %>"><%- year %>年
</h4>
<% } %>
<div class="articles">
<div class="article content>">
<div class="article-sort-post">
<div class="article-sort-item_title">
<a href="<%- url_for(post.path) %>">
<h5>
<i class="fa fa-clock">														 </i>
<time class="is-text-small" datetime="2021-08-20T20:20:00.000Z" itemprop="datePublished">
<%- date(post.date, 'YYYY-MM-DD') %>
</time>
</h5>
</a>
<h6 class="is-6">
<a href="<%- url_for(post.path) %>"></a>
<a href="<%- url_for(post.path) %>">
<%= post.title %></a>
</h6>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<% }); %>
</div>

查看我的效果:

Front-matter

Front-matter 選項詳解

Front-matter 選項中的所有內容均為非必填的。但仍然建議至少填寫 titledate 的值。

配置選項 默認值 描述
title Markdown 的文件標題 文章標題,強烈建議填寫此選項
date 文件創建時的日期時間 發布時間,強烈建議填寫此選項,且最好保證全局唯一
author _config.yml 中的 author 文章作者
img featureImages 中的某個值 文章特征圖
top true 推薦文章(文章是否置頂),如果 top 值為 true,則會作為首頁推薦文章
cover false 表示該文章是否需要加入到首頁輪播封面中
coverImg 表示該文章在首頁輪播封面需要顯示的圖片路徑,如果沒有,則默認使用文章的特色圖片
password 文章閱讀密碼,如果要對文章設置閱讀驗證密碼的話,就可以設置 password 的值,該值必須是用 SHA256 加密后的密碼,防止被他人識破。前提是在主題的 config.yml 中激活了 verifyPassword 選項
toc true 是否開啟 TOC,可以針對某篇文章單獨關閉 TOC 的功能。前提是在主題的 config.yml 中激活了 toc 選項
mathjax false 是否開啟數學公式支持 ,本文章是否開啟 mathjax,且需要在主題的 _config.yml 文件中也需要開啟才行
summary 文章摘要,自定義的文章摘要內容,如果這個屬性有值,文章卡片摘要就顯示這段文字,否則程序會自動截取文章的部
tags 文章標簽,一篇文章可以多個標簽
categories 文章分類,本主題的分類表示宏觀上大的分類,只建議一篇文章一個分類
keywords 文章標題 文章關鍵字,SEO 時需要
reprintPolicy cc_by 文章轉載規則, 可以是 cc_by, cc_by_nd, cc_by_sa, cc_by_nc, cc_by_nc_nd, cc_by_nc_sa, cc0, noreprint 或 pay 中的一個

注意:

  1. 如果 img 屬性不填寫的話,文章特色圖會根據文章標題的 hashcode 的值取余,然后選取主題中對應的特色圖片,從而達到讓所有文章都的特色圖各有特色。

  2. date 的值盡量保證每篇文章是唯一的,因為本主題中 Gitalk 和 Gitment 識別 id 是通過 date 的值來作為唯一標識的。

  3. 如果要對文章設置閱讀驗證密碼的功能,不僅要在 Front-matter 中設置采用了 SHA256 加密的 password 的值,還需要在主題的 _config.yml 中激活了配置。有些在線的 SHA256 加密的地址,可供使用:開源中國在線工具、chahuo、站長工具。

  4. 您可以在文章md文件的front-mater中指定reprintPolicy來給單個文章配置轉載規則.

最全示例

---
title: 基于Hexo的hexo-theme-matery主題搭建博客并優化
date: 2019-10-03 14:25:00
author: 悟塵
img: /source/images/xxx.jpg
top: true
cover: true
coverImg: /images/1.jpg
password: 8d969eef6ecad3c29a3a629280e686cf0c3f5d5a86aff3ca12020c923adc6c92
toc: false
mathjax: false
summary: 這是你自定義的文章摘要內容,如果這個屬性有值,文章卡片摘要就顯示這段文字,否則程序會自動截取文章的部分內容作為摘要
categories: 工具
tags:
- blog
- hexo
---

總結

以上是生活随笔為你收集整理的hexo博客主题推荐_wordpress社交主题(Hexo系列)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。