惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

宝玉的分享
宝玉的分享
NISL@THU
NISL@THU
E
Exploit-DB.com RSS Feed
L
LINUX DO - 热门话题
L
Lohrmann on Cybersecurity
K
Kaspersky official blog
Project Zero
Project Zero
Cisco Talos Blog
Cisco Talos Blog
T
The Exploit Database - CXSecurity.com
P
Palo Alto Networks Blog
C
CXSECURITY Database RSS Feed - CXSecurity.com
T
Threatpost
S
Schneier on Security
G
GRAHAM CLULEY
The Hacker News
The Hacker News
T
Threat Research - Cisco Blogs
Scott Helme
Scott Helme
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
P
Privacy & Cybersecurity Law Blog
C
Cyber Attacks, Cyber Crime and Cyber Security
Cyberwarzone
Cyberwarzone
C
CERT Recently Published Vulnerability Notes
T
Tor Project blog
AWS News Blog
AWS News Blog
Simon Willison's Weblog
Simon Willison's Weblog
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
爱范儿
爱范儿
P
Privacy International News Feed
云风的 BLOG
云风的 BLOG
P
Proofpoint News Feed
S
Securelist
G
Google Developers Blog
The Last Watchdog
The Last Watchdog
Google Online Security Blog
Google Online Security Blog
美团技术团队
F
Fortinet All Blogs
小众软件
小众软件
Recorded Future
Recorded Future
V
Visual Studio Blog
B
Blog RSS Feed
H
Help Net Security
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
Google DeepMind News
Google DeepMind News
Blog — PlanetScale
Blog — PlanetScale
博客园 - 聂微东
Stack Overflow Blog
Stack Overflow Blog
Martin Fowler
Martin Fowler
Latest news
Latest news
Spread Privacy
Spread Privacy
H
Heimdal Security Blog

爱吃肉的猫

那就,再相逢 Butterfly的魔改教程:最新评论页 离歌不夜天 前端分享 - 滑动阻尼效果 Butterfly的魔改教程:右键菜单 音乐分享 - doi微醺氛围 Butterfly的魔改教程:动态相册页 近况记事 - 11 微信公众号:Ai大模型让回复更具智能化 近况记事 - 10 PWA:让你的网站变成桌面应用APP Healthy Love Butterfly的魔改教程:关于本站 近况记事 - 9 Butterfly的魔改教程:待办清单 TrollStore - 不掉签助手 近况记事 - 8 Twikoo评论回复邮件模版 过一个很特别的七夕 The Young Boy and the Sea Butterfly的魔改教程:文章订阅页 思考题目:混乱是阶梯 近况记事 - 7 Butterfly的魔改教程:即刻短文页 Butterfly的魔改教程:loading加载动画 差旅游记 再见,不惑之年:二十又一 近况记事 - 6 Butterfly的魔改教程:自定页数跳转 堆友AI作图:3D资源设计平台,堆出你的未来 【QD-Today】自建私有自动签到服务 Long time no see Butterfly的魔改教程:聊天记录页 Butterfly的魔改教程:个性定位信息 近况记事 - 5 Butterfly的魔改教程:好物推荐页 CDN加速 二刷《想见你》 网络言论不是法外之地 近况记事 - 4 深夜训斥 近况记事 - 3 近况记事 - 2 日常打理的那些事 Butterfly的魔改教程:随机阅读一篇文章 随笔 · 封 布柒糖FM项目进展报告 清明路雨纷纷 TA - 仲夏夜的荒原 重构记录 - 4 近况记事 2021款 Model Y 近两年用车总结 重构记录 - 3 百日祭 避风的港湾 Emoji表情大全 iCat-APP 开源记录 Butterfly的调整教程:文章外挂标签美化 iOS修改 - 万铲铲的致富之路 Markdown 基础教程 从你的全世界路过 小米摄像头!避!雷! VuePress 搭建教程 Hexo跳过指定文件渲染 百度贴吧每日自动签到 重构记录 - 1 GitHub Desktop提交报错 快速批量处理重命名 Git连接仓库常用命令 Ubuntu处理deb命令 掘金自动签到并挖矿 一个简洁的橙色调个人简介 我的猫以前也是流浪猫 布柒糖FM 最新指北 初学写个了油猴脚本 幽灵404页面 PC游戏 · 植物大战僵尸 语言包 · 越狱篇 砸壳多开 · 越狱篇 HuiRan Cursors 手动关闭Win10自动更新 iPhone XR 完美越狱 成功实例 三年的跌撞 关于《小橘妈妈》 魔改前置教程:添加自定义css和js文件 Hexo 博客添加RSS插件 Butterfly的魔改教程:导航栏魔改美化
Butterfly的魔改教程:评论弹窗
亦小封 · 2023-03-06 · via 爱吃肉的猫

本篇魔改教程只适用于 Twikoo评论 ,其他评论系统可自行修改适配。
并且内容会有涉及到最新评论页的部分js常量函数,请优先阅读:Butterfly的魔改教程:最新评论页

效果预览

在PC端文章右下角处即可查看评论弹窗

创建数据

小节开始前,提醒事项。
对于初次魔改新手,建议先过一遍:魔改前置教程:添加自定义css和js文件

  • [主题目录]/layout/includes/layout.pug文件中,新增以下内容。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
      main#content-inner.layout(class=hideAside)
if body
div!= body
else
block content
if theme.aside.enable && page.aside !== false
include widget/index.pug

+ if page.comments !== undefined && page.comments !== false && theme.comments.use
+ #comment-barrage

- const footerBg = theme.footer_img
- const footer_bg = footerBg ? footerBg
footer#footer(style=footer_bg)
!=partial('includes/footer', {}, {cache: true})
  • 新建[主题目录]/source/css/_layout/barrage.styl样式文件,并新增以下内容。
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
#comment-barrage
position fixed
bottom 40px
right calc(10px + 48px)
display flex
flex-direction column
justify-content flex-end
align-items flex-end
transform translateY(190px)
transition .3s
z-index 1

+maxWidth768()
display none

&.show
transform translateY(0)

.comment-barrage-item
min-width 286px
max-width 286px
width fit-content
min-height 80px
max-height 150px
margin 4px
padding 8px 14px
background var(--icat-card-overlap)
border-radius 12px
color var(--icat-fontcolor)
animation barrageIn .6s cubic-bezier(0.42, 0, 0.3, 1.11)
transition .3s
display flex
flex-direction column
outline var(--icat-border-always)
position fixed
box-shadow var(--icat-shadow-border)
overflow hidden

&:hover
outline var(--icat-border-main)
box-shadow var(--icat-shadow-main)

&.out
opacity 0
animation barrageOut 0.6s cubic-bezier(0.42, 0, 0.3, 1.11)

pre, li, blockquote, br
display none

.barrageHead
height 30px
padding 0
line-height 30px
font-size 12px
border-bottom var(--icat-border-dashed)
display flex
justify-content space-between
align-items center
font-weight bold
padding-bottom 6px

.barrageAvatar
width 18px
height 18px
margin 0
margin-right 8px
border-radius 50%
background var(--icat-theme)

.barrageTime
margin-left 4px

.barrageClose
color var(--icat-secondtext)
cursor pointer
line-height 1
margin-left auto

&:hover
color var(--icat-theme)

.barrageContent
font-size 14px
font-weight normal
height calc(100% - 30px)
overflow hidden
width fit-content
max-height 48px

a
pointer-events:none
font-size 14px

&:-webkit-scrollbar
height 0
width 4px

&-button
display none

p
color var(--icat-fontcolor)
margin 8px 0 0
max-width calc(286px - 28px)
line-height 1.5
-webkit-line-clamp 2
display -webkit-box
-webkit-box-orient vertical
font-size 12px
font-weight bold
overflow hidden
text-overflow ellipsis
transition .3s

&:hover
color var(--icat-theme)

img
&:not(.tk-owo-emotion)
display none

&.tk-owo-emotion
width 16px
padding 0
margin 0
transform translateY(2px)

@keyframes barrageIn
0%
transform translateY(20px)
opacity 0

100%
transform translateY(0)
opacity 1

@keyframes barrageOut
0%
transform translateY(0)
opacity 1

100%
transform translateY(20px)
opacity 0
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
let commentData
+let commentInterval = null

const comment = {
fetchData: async (option) => {
const res = await fetch('{envId}', {
method: "POST",
body: JSON.stringify({
"event": "GET_RECENT_COMMENTS",
"accessToken": "{YOUR_TOKEN}",
"includeReply": true,
"pageSize": -1,
...option
}),
headers: { 'Content-Type': 'application/json' }
}).then(res => res.json())

return res.data
},

···

+ barrage: async () => {
+ const tlol = btf.saveToLocal.get('comment-pop')
+ const barrage = document.getElementById('comment-barrage')
+ if (tlol === 'off' || !barrage) return
+
+ const ScrollBarrage = () => {
+ const scrollResidue = (window.scrollY + document.documentElement.clientHeight) >= (document.getElementById("post-comment") || document.getElementById("footer")).offsetTop
+ barrage.classList.toggle('show', !scrollResidue)
+ }
+ const BarrageBox = (data) => {
+ const time = changeTime(new Date(data.created).toISOString(), true)
+
+ let barrages = document.createElement('div')
+ barrages.className = 'comment-barrage-item'
+ barrages.innerHTML = `<div class="barrageHead"><img class="barrageAvatar" src="${data.avatar}" /><div class="barrageNick">${data.nick}</div><div class="barrageTime">${time}曾评论</div><a class="barrageClose" href="javascript:comment.closeBarrage(true)"><i class="MeuiCat icon-close-fill"></i></a></div><a class="barrageContent" href="javascript:void(0)" onclick="btf.scrollToDest(btf.getEleTop(document.getElementById('${data.id}')), 300)"><p>${data.commentText.trim()}</p></a>`
+
+ box.push(barrages)
+ barrage.append(barrages)
+ }
+ const removeBarrage = (e) => {
+ if (!e) return
+ e.className = 'comment-barrage-item out'
+ setTimeout(() => barrage.removeChild(e), 1000)
+ }
+
+ btf.addEventListenerPjax(window, 'scroll', ScrollBarrage, { passive: true })

+ let hoverBarrage = false, index = 0, box = []
+ const url = `"url": window.location.pathname`
+ const data = await comment.fetchData(url)
+ if (!data.length) return

+ barrage.addEventListener('mouseenter', () => hoverBarrage = true)
+ barrage.addEventListener('mouseleave', () => hoverBarrage = false)

+ clearInterval(commentInterval)
+ commentInterval = setInterval(() => {
+ if (box.length >= 1 && !hoverBarrage) removeBarrage(box.shift())
+ if (!hoverBarrage) {
+ BarrageBox(data[index])
+ index = (index + 1) % data.length
+ }
+ }, 5000)
+ },
+ closeBarrage: (state = false) => {
+ const removeBarrage = () => {
+ const $comment = document.querySelector('#comment-barrage')
+ $comment.className = 'out'
+ setTimeout(() => { $comment.innerHTML = '', $comment.className = 'show' }, 1000)
+ }
+
+ if (state) return clearInterval(commentInterval), removeBarrage()
+
+ const comments = btf.saveToLocal.get('comment-pop')
+ btf.saveToLocal.set('comment-pop', comments === 'off' ? 'on' : 'off', 2)
+ comments === 'off' ? comment.barrage() : (clearInterval(commentInterval), removeBarrage())
+ }
}
btf.addGlobalFn('pjaxComplete', comment.new(), 'comment')
+btf.addGlobalFn('pjaxComplete', comment.barrage(), 'barrage')

注意:如果你没有实现最新评论页功能,就需要新增整个comment函数,并将 {envId}{YOUR_TOKEN} 需要替换为对应值

旧版教程

引用站外地址,注意辨别

Butterfly的魔改教程:最新评论页 - 热评弹窗

显示全站最新评论内容,快速预览;内附评论总数显示、热评弹窗教程

更新历史

  • 240702 更新:热评弹窗优化、UI调整、教程地址更新

Butterfly的魔改教程:评论弹窗

此文章版权归 MeuiCat 所有,完整转载,请注明来源!