您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Greasy Fork is available in English.
在网页添加一个“回到顶部”的按钮,可以快速回到页面顶部。
当前为
// ==UserScript== // @name 滚动到顶部按钮 // @namespace http://tampermonkey.net/ // @version 1.6 // @description 在网页添加一个“回到顶部”的按钮,可以快速回到页面顶部。 // @author Techwb.cn // @match *://*/* // @grant none // @license MIT // ==/UserScript== (function() { 'use strict'; // 创建按钮元素 var scrollButton = document.createElement('button'); scrollButton.textContent = '回到顶部'; scrollButton.id = 'scroll-top-button'; // 添加按钮样式 scrollButton.style.background = 'red'; // 将背景颜色改为红色 scrollButton.style.border = 'none'; // 去掉边框 scrollButton.style.color = 'white'; // 文字颜色为白色 scrollButton.style.padding = '10px 10px'; // 设定按钮的内边距 scrollButton.style.textAlign = 'center'; // 文字居中 scrollButton.style.textDecoration = 'none'; // 去掉下划线 scrollButton.style.display = 'none'; // 默认不显示 scrollButton.style.borderRadius = '10px'; // 设定圆角 scrollButton.style.boxShadow = '2px 2px 3px rgba(0, 0, 0, 0.3)'; // 添加阴影效果 scrollButton.style.cursor = 'pointer'; // 设定鼠标样式为手型 scrollButton.style.position = 'fixed'; // 设定固定定位 scrollButton.style.bottom = '8%'; // 设定距离底部的距离 scrollButton.style.right = '20px'; // 设定距离右侧的距离 scrollButton.style.zIndex = '9999'; // 设定 z-index // 添加鼠标悬停效果 scrollButton.addEventListener('mouseenter', function() { scrollButton.style.backgroundColor = '#ff6347'; // 鼠标悬停时的背景颜色 }); scrollButton.addEventListener('mouseleave', function() { if (scrollButton.textContent === '回到顶部') { scrollButton.style.backgroundColor = 'red'; // 鼠标离开时的背景颜色 } else { scrollButton.style.backgroundColor = 'blue'; // 鼠标离开时的背景颜色 } }); // 添加按钮到页面 document.body.appendChild(scrollButton); // 当用户滚动页面时,如果已经滚动了一定距离,就显示按钮 window.addEventListener('scroll', function() { var scrollPercentage = window.pageYOffset / (document.documentElement.scrollHeight - window.innerHeight) * 100; if (scrollPercentage > 25) { //状态切换位置百分比滚动条 scrollButton.textContent = '回到顶部'; scrollButton.style.background = 'red'; } else { scrollButton.textContent = '回到底部'; scrollButton.style.background = 'blue'; } if (window.pageYOffset > 100) { // 滚动距离超过 100px 时 scrollButton.style.display = 'block'; // 显示按钮 } else { scrollButton.style.display = 'none'; // 否则隐藏按钮 } }); // 点击按钮时,回到页面顶部或底部 var hasScrolledToTop = false; // 标记是否已经滚动到顶部 var lastScrollPosition = 0; // 上一次滚动的位置 scrollButton.addEventListener('click', function() { if (scrollButton.textContent === '回到顶部') { window.scrollTo(0, 0); // 将页面滚动到顶部 scrollButton.textContent = '回到底部'; // 修改按钮文本内容 scrollButton.style.background = 'blue'; // 修改按钮背景颜色 hasScrolledToTop = true; // 将标记设为 true } else { if (window.pageYOffset === document.documentElement.scrollHeight - window.innerHeight) { window.scrollTo(0, 0); // 如果滚动条在底部,回到顶部 } else { lastScrollPosition = window.pageYOffset; // 记录当前滚动位置 sessionStorage.setItem('lastScrollPosition', lastScrollPosition); // 将当前滚动位置存储到 sessionStorage 中 window.scrollTo(0, document.documentElement.scrollHeight - window.innerHeight); // 滚动到页面底部 } scrollButton.textContent = '回到顶部'; // 修改按钮文本内容 scrollButton.style.background = 'red'; // 修改按钮背景颜色 hasScrolledToTop = false; // 将标记设为 false } }); })();