一键回到顶部
// ==UserScript==
// @name To Top
// @namespace https://github.com/RANSAA
// @version 0.0.1
// @description 一键回到顶部
// @author sayaDev
// @license MIT License
// @icon 
// @match http://*/*
// @match *://*/*
// @grant none
// @compatible chrome
// @compatible edge
// @compatible firefox
// @compatible opera
// @compatible safari
// @noframes
// ==/UserScript==
/**
* 说明:
*
* noframes: 禁止脚本在iframe中运行
*
* compatible:greasyfork.org脚本站点兼容性图标
*
**/
//是否开启滚动动画
let toTopAnination = 1;
(function() {
'use strict';
addToTopButton();
})();
function addToTopButton(){
// 首先查询页面上是否存在TKToast元素
let existingTKToTop = document.querySelector('TKToTop');
if (existingTKToTop) {
return;
}
//创建style
addToTopStyle();
let toTop = createSVGToTop()
toTop.setAttribute("class","TKToTopStyle");
//定义的是事件被触发后要做的事情
toTop.addEventListener("click", function() {
if (toTopAnination == 1){
window.scrollTo({left:0,top:0,behavior:'smooth'});
}else{
window.scrollTo(0,0);
}
});
// 创建一个包含按钮的DIV元素
const toToDIV = document.createElement("TKToTop");
toToDIV.setAttribute("class","TKToTopStyle");
// 将按钮添加到DIV中
toToDIV.appendChild(toTop);
// 添加到body中
document.body.appendChild(toToDIV);
}
function createSVGToTop()
{
var svgElement = document.createElementNS("http://www.w3.org/2000/svg", "svg");
svgElement.setAttribute("width", "44");
svgElement.setAttribute("height", "44");
// svgElement.setAttribute("style", "background-color: transparent"); // 设置透明背景色
// 创建一个<circle>元素
var circleElement = document.createElementNS("http://www.w3.org/2000/svg", "circle");
circleElement.setAttribute("cx", "22");
circleElement.setAttribute("cy", "22");
circleElement.setAttribute("r", "20");
circleElement.setAttribute("fill", "#1ca7ee");
// 创建一个<text>元素并设置其属性和样式
var textElement = document.createElementNS("http://www.w3.org/2000/svg", "text");
textElement.setAttribute("x", "50%"); // 居中对齐
textElement.setAttribute("y", "50%");
textElement.setAttribute("text-anchor", "middle"); // 文本居中对齐
textElement.setAttribute("dominant-baseline", "middle"); // 文本垂直居中对齐
textElement.setAttribute("fill", "white");
textElement.setAttribute("font-size", "14px");
textElement.setAttribute("font-weight", "700"); // 设置字体粗细
textElement.style.fontFamily = "Arial"; // 设置字体样式,如果需要的话
textElement.textContent = "Top";
// 将<circle>和<text>元素添加到<svg>元素中
// svgElement.appendChild(circleElement);
svgElement.appendChild(textElement);
return svgElement;
}
function addToTopStyle(){
const style = `
.TKToTopStyle{
background: #1ca7ee;
background-color: #1ca7ee;
color: #ffffff;
right: 16px;
bottom: 20px;
position: fixed;
z-index: 999999;
width: 44px;
height: 44px;
border: none;
cursor: pointer;
padding: 0;
border: 1px solid;
border-color: #1ca7ee;
border-radius: 50% ;
box-shadow: 0px 0px 8px #1ca7ee;
margin: 0; /* 确保没有外边距 */
padding: 0; /* 确保没有内边距 */
lineHeight: 1; /* 确保行高不影响布局 */
outline: none; /* 移除可能的外部边框 */
display: 'block'; /* 设置为块级元素 */
}
.TKToTopStyle:active,
.TKToTopStyle:hover{
box-shadow: 0px 0px 16px #1ca7ee;
}
`;
var styleId = "TKToTopStyle";
// 首先查询页面上是否存在具有给定ID的<style>元素
var existingStyle = document.getElementById(styleId);
//如果存在则跳过
if (existingStyle) {
return;
}
var myStyle = document.createElement("style");
myStyle.type="text/css";
myStyle.id = styleId;
myStyle.innerHTML = style;
document.head.appendChild(myStyle);
}