mirror of
https://github.com/jerryc127/hexo-theme-butterfly.git
synced 2025-09-15 12:58:48 +08:00
1. 不再支持hexo 4.0.0以下版本 2. 添加hexo fragment_cache,加快生成速度 3. 完善V5圖標顯示,不再需要同時加載V4和v5圖標 4. 去除cheerio依賴 5. 整合豆瓣配置,增加配置遊戲,圖書頁面top_img,可設置是否設置meta,解決部分瀏覽器無法顯示圖片問題 6. 友情鏈接除列表外可自定義內容 7. 可設置主頁標題距離頂部距離 8. 側邊欄可隱藏,可設置手機頁面是否隱藏 9. 增加disqusjs和utterances 兩個評論 10. 主頁文章增加tags和更新日期顯示,可以配置post_meta 11. 首頁subtitle可關閉打字效果,可設置打字效果顯示一次或loop 12. 增加valine和gitalk的配置 13. darkmode配置整理 14. 增加404頁面 15. post_beautify改為beautify,頁面美化不再只限於post頁,page頁也一樣 16. 可設置是否顯示cover,可設置各位置的cover顯示 17. 增加mermaid,可畫流程圖、狀態圖、時序圖、甘特圖等等 18. 增加pangu配置,中英文之間添加空格 19. 整合部分配置 20. post-copyright增加decode網址 (可以顯示中文) 21. 增加部分顏色配置 Feature 1. 適配IE 2. 增加一個Tag Plugins: 圖庫集 3. 增加一個Tag Plugins: tag-hide 功能 inline/block 4. 去除page頁開頭顯示與標題一樣的內容 5. aside 公告欄設置,支持html代碼 6. 手機界面sidebar顯示進度條和加深對應的標題 7. 主頁subtitle 的 hitokoto 顯示內容出處 9. footer 的hexo鏈接改為https 10. 修改手機下,menus和toc的打開效果 11. 手機頁面下,搜索界面全屏顯示 12. SEO優化,標題欄改為h1顯示 13. 閲讀模式優化,可根據light mode 和darkmode調整背景 14. 當屏蔽js時,header會出現(之前用js控制,會隱藏) Fixed 1. 修復Tencent Analytics的script加載為https #105 2. 修復相關文章,日期顯示錯誤bug 3. 修復gitalk報錯問題 4. 修復當valine background 是絕對地址時無法顯示的bug 5. 修復medium-zoom 無法使用的bug 6. 修復在safari下,點擊或移動到首頁文章cover,圓角變成正方形的bug #114 7. 修復在部分瀏覽器下,aside,友情鏈接頭像轉動變形的bug 8. 修復在寬度限制下,表格內容溢出屏幕外而出現滾動條的bug \#138 9. 修復gitalk js 在一些沒有設置評論的page里加載的bug 10. 修復tag plugins 的gist 在不同主題下的背景顏色問題(黑色主題下,文字不易觀看) 11. 修復highlight figcaption 顯示不全的bug 12. 修復disqus評論數無法獲取的bug 13. 修復子目錄在觸摸屏下點擊,偶爾不出現的bug 14. 修復a標籤太長(連續英文字母)不會換行的bug 15. 修復toc滾動時,閲讀進度條也跟著滾動的bug 16. 修復aside的圖片,可點擊顯示大圖bug 17. 修復activate-power-mode設置參數無效bug 18. 修復語言上的錯誤 \#156 19. 修復主頁在safari桌面端,首頁滾動卡頓的bug
88 lines
2.6 KiB
JavaScript
88 lines
2.6 KiB
JavaScript
! function () {
|
|
var cn = document.getElementById('canvas_nest');
|
|
var mb = cn.getAttribute("mobile");
|
|
|
|
if (mb == 'false' && (/Android|webOS|iPhone|iPod|iPad|BlackBerry/i.test(navigator.userAgent))) {
|
|
return;
|
|
}
|
|
|
|
function o(w, v, i) {
|
|
return w.getAttribute(v) || i
|
|
}
|
|
|
|
function j(i) {
|
|
return document.getElementsByTagName(i)
|
|
}
|
|
|
|
function l() {
|
|
var i = j("script"),
|
|
w = i.length,
|
|
v = i[w - 1];
|
|
return {
|
|
l: w,
|
|
z: o(v, "zIndex", -1),
|
|
o: o(v, "opacity", 0.5),
|
|
c: o(v, "color", "0,0,0"),
|
|
n: o(v, "count", 99)
|
|
}
|
|
}
|
|
|
|
function k() {
|
|
r = u.width = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth, n = u.height = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight
|
|
}
|
|
|
|
function b() {
|
|
e.clearRect(0, 0, r, n);
|
|
var w = [f].concat(t);
|
|
var x, v, A, B, z, y;
|
|
t.forEach(function (i) {
|
|
i.x += i.xa, i.y += i.ya, i.xa *= i.x > r || i.x < 0 ? -1 : 1, i.ya *= i.y > n || i.y < 0 ? -1 : 1, e.fillRect(i.x - 0.5, i.y - 0.5, 1, 1);
|
|
for (v = 0; v < w.length; v++) {
|
|
x = w[v];
|
|
if (i !== x && null !== x.x && null !== x.y) {
|
|
B = i.x - x.x, z = i.y - x.y, y = B * B + z * z;
|
|
y < x.max && (x === f && y >= x.max / 2 && (i.x -= 0.03 * B, i.y -= 0.03 * z), A = (x.max - y) / x.max, e.beginPath(), e.lineWidth = A / 2, e.strokeStyle = "rgba(" + s.c + "," + (A + 0.2) + ")", e.moveTo(i.x, i.y), e.lineTo(x.x, x.y), e.stroke())
|
|
}
|
|
}
|
|
w.splice(w.indexOf(i), 1)
|
|
}), m(b)
|
|
}
|
|
var u = document.createElement("canvas"),
|
|
s = l(),
|
|
c = "c_n" + s.l,
|
|
e = u.getContext("2d"),
|
|
r, n, m = window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame || function (i) {
|
|
window.setTimeout(i, 1000 / 45)
|
|
},
|
|
a = Math.random,
|
|
f = {
|
|
x: null,
|
|
y: null,
|
|
max: 20000
|
|
};
|
|
u.id = c;
|
|
u.style.cssText = "position:fixed;top:0;left:0;z-index:" + s.z + ";opacity:" + s.o;
|
|
j("body")[0].appendChild(u);
|
|
k(), window.onresize = k;
|
|
window.onmousemove = function (i) {
|
|
i = i || window.event, f.x = i.clientX, f.y = i.clientY
|
|
}, window.onmouseout = function () {
|
|
f.x = null, f.y = null
|
|
};
|
|
for (var t = [], p = 0; s.n > p; p++) {
|
|
var h = a() * r,
|
|
g = a() * n,
|
|
q = 2 * a() - 1,
|
|
d = 2 * a() - 1;
|
|
t.push({
|
|
x: h,
|
|
y: g,
|
|
xa: q,
|
|
ya: d,
|
|
max: 6000
|
|
})
|
|
}
|
|
setTimeout(function () {
|
|
b()
|
|
}, 100)
|
|
}(); |