添加回到顶/底部按钮
// ==UserScript==
// @name Twitter 添加顶部底部按钮
// @namespace http://tampermonkey.net/
// @version 1.0.0
// @description 添加回到顶/底部按钮
// @author Ari
// @match *.twitter.com/*
// @match *.x.com/*
// @icon https://abs.twimg.com/favicons/twitter.2.ico
// @grant none
// @license GPL-3.0 License
// ==/UserScript==
;(function () {
;('use strict')
// 顶部按钮图标 (Base64)
const top =
''
// 底部按钮图标 (Base64)
const bottom =
''
const name = 'Twitter Helper'
const logPrefix = ['%c' + name, `background:#1d9bf0;border-radius: 0.5em;color: white;font-weight: bold;padding: 2px 0.5em`]
function log(...args) {
console.log(...logPrefix, ...args)
}
function addScrollButton() {
log('addScrollButton...')
let text = `<div id="nogi-scroll" style="position: fixed;bottom: 100px;left: 55px;z-index: 999;">
<div class='nogi-line' id='top' >
<img class='nogi-icon' src="${top}">
</div>
<div class='nogi-line' id='bottom' >
<img class='nogi-icon' src="${bottom}">
</div>
</div>`
let style = document.createElement('style')
style.innerHTML = `
#nogi-scroll {
display: flex;
background: transparent;
border-radius: 26px;
align-items: center;
justify-content: center;
flex-direction: column;
}
#top {
display: block;
}
#bottom {
display: block;
}
.nogi-line {
border: 1px solid #1d9bf0;
border-radius:50%;
margin: 5px;
background: white;
}
.nogi-line:hover {
background: #d2ecfd;
}
.nogi-icon {
position: relative;
border-radius:50%;
padding: 5px 5px 0px 5px;
width: 30px;
height: 30px;
cursor: pointer;
}
`
let el = document.createElement('div')
el.innerHTML = text
document.head.append(style)
document.body.append(el)
let topButton = document.getElementById('top')
let bottomButton = document.getElementById('bottom')
// 回到顶部事件
topButton.onclick = function () {
let scrollInterval = setInterval(() => {
let nowY = window.scrollY;
// 到达顶部(或非常接近顶部)时停止
if (nowY <= 0) {
clearInterval(scrollInterval);
window.scrollTo(0, 0); // 确保归零
} else {
// 每次向上移动剩余距离的 1/5 (模拟减速效果),最少移动 50px
let speed = Math.max(50, nowY / 5);
window.scrollBy(0, -speed);
}
}, 15); // 每 15ms 执行一次,比原生 smooth 更强硬
}
// 去到底部事件
bottomButton.onclick = function () {
window.scrollTo({
top: document.body.scrollHeight,
behavior: 'smooth',
})
}
}
// 每隔0.5秒检查一次按钮是否存在(防止页面刷新后消失)
let dd = setInterval(() => {
let nogiScroll = document.querySelector('#nogi-scroll')
if (nogiScroll == null) {
addScrollButton()
}
}, 500)
// 10秒后停止定时检查,节省性能
window.onload = () => {
setTimeout(() => {
clearInterval(dd)
}, 10000)
}
})()