平滑的滚动到顶部/底部

为网页增加滚到顶部和底部按钮

Per 03-04-2015. Zie de nieuwste versie.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey, Greasemonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Userscripts.

Voor het installeren van scripts heb je een extensie nodig, zoals {tampermonkey_link:Tampermonkey}.

Voor het installeren van scripts heb je een gebruikersscriptbeheerder nodig.

(Ik heb al een user script manager, laat me het downloaden!)

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

(Ik heb al een beheerder - laat me doorgaan met de installatie!)

// ==UserScript==
// @name	平滑的滚动到顶部/底部
// @author	burningall
// @description	为网页增加滚到顶部和底部按钮
// @version     2015.4.3-1.0
// @include			http://*
// @include			https://*
// @include			ftp://*
// @supportURL		http://www.burningall.com
// @contributionURL	[email protected]|alipay.com
// @namespace https://greatest.deepsurf.us/zh-CN/users/3400-axetroy
// ==/UserScript==

function addEvent(obj, event, fn) {
	return obj.addEventListener ? obj.addEventListener(event, fn, false) : obj.attachEventListener("on" + event, fn);
};
function getScrollHeight() {
	return document.body ? bodyScrollHeight = document.body.scrollHeight: document.documentElement.scrollHeight;
};
function getClientHeight() {
	return document.documentElement ? document.documentElement.clientHeight: document.body.clientHeight;
};
function hasScroll() {
	var hasScroll;
	return getScrollHeight() > getClientHeight() ? hasScroll = 1 : hasScroll = 0;
}; (addEvent(window.top, "load",
function() {
	if (hasScroll() == 1) {
		function $(id) {
			return document.getElementById(id);
		}
		function getStyle(obj, attr) {
			return obj.currentStyle ? obj.currentStyle[attr] : getComputedStyle(obj)[attr];
		}
		function getScrollTop() {
			return document.documentElement.scrollTop ? document.documentElement.scrollTop: document.body.scrollTop;
		}
		function getClientHeight() {
			return document.documentElement ? document.documentElement.clientHeight: document.body.clientHeight;
		}
		function createElement(tagName, idName, styleList, appendPosition, endFn) {
			var newElement = document.createElement(tagName);
			newElement.id = idName;
			newElement.style.cssText = styleList;
			appendPosition && appendPosition.appendChild(newElement);
			endFn && endFn();
		}
		function doMove(obj, attr, dir, target, endFn) {
			dir = parseInt(getStyle(obj, attr)) < target ? dir: -dir;
			clearInterval(obj.timer);
			obj.timer = setInterval(function() {
				var speed = parseInt(getStyle(obj, attr)) + dir;
				if (speed > target && dir > 0 || speed < target && dir < 0) {
					speed = target;
				}
				obj.style[attr] = speed + "px";
				if (speed == target) {
					clearInterval(obj.timer);
					endFn && endFn();
				}
			},
			30);
		}
		createElement("div", "scrollMars-troy", "width:100px;height:120px;position:fixed;right:20px;z-index:9999;", document.documentElement);
		$("scrollMars-troy").innerHTML = "<div id='goTop-troy' class='Top-and-Btn'></div><div id='goBtn-troy' class='Top-and-Btn'></div>";
		var scrollStyle = "width:40px;height:40px;text-align:center;padding:5px;margin:5px auto;background:#303030;color:#fff;display:block;opacity:0.8;fitter:alpha(opacity:80);cursor:pointer;border-radius:50%;box-shadow:2px 2px 40px 2px #303030;font-size:16px;z-index:9999";
		$('scrollMars-troy').style.top=(getClientHeight()/3)+'px';
		$("goTop-troy").style.cssText = scrollStyle;
		$("goBtn-troy").style.cssText = scrollStyle;
		$("goTop-troy").innerHTML = "顶<br/>部";
		$("goBtn-troy").innerHTML = "底<br/>部";
		addEvent($("goTop-troy"), "click",
		function() {
			clearInterval($("goTop-troy").timerScroll);
			$("goTop-troy").timerScroll = setInterval(function() {
				var speed = (getScrollTop() / 5) + 10;
				position = getScrollTop() - speed;
				if (position <= 0) {
					document.body.scrollTop = document.documentElement.scrollTop = 0;
					clearInterval($("goTop-troy").timerScroll);
					$("goTop-troy").timerScroll = null;
				}
				document.body.scrollTop = document.documentElement.scrollTop = position;
			},
			30);
		});
		addEvent($("goBtn-troy"), "click",
		function() {
			clearInterval($("goTop-troy").timerScroll);
			$("goTop-troy").timerScroll = setInterval(function() {
				var speed = (getScrollTop() / 5) + 10;
				position = getScrollTop() + speed;
				if (position + getClientHeight() >= getScrollHeight()) {
					document.body.scrollTop = document.documentElement.scrollTop = getScrollHeight();
					clearInterval($("goTop-troy").timerScroll);
					$("goTop-troy").timerScroll = null;
				}
				document.body.scrollTop = document.documentElement.scrollTop = position;
			},
			30);
		});
		addEvent($("scrollMars-troy"), "mouseover",
		function() {
			clearTimeout($("scrollMars-troy").timerHover);
			doMove($("scrollMars-troy"), "right", 10, 20,
			function() {
				doMove($("scrollMars-troy"), "width", 20, 100);
			});
		});
		addEvent($("scrollMars-troy"), "mouseout",
		function() {
			clearTimeout($("scrollMars-troy").timerHover);
			$("scrollMars-troy").timerHover = setTimeout(function() {
				doMove($("scrollMars-troy"), "right", 10, -80,
				function() {
					doMove($("scrollMars-troy"), "width", 20, 160);
				});
			},
			3000);
		});
		addEvent($("goTop-troy"), "mouseover",
		function() {
			$("goTop-troy").style.background = "#FF0004";
		});
		addEvent($("goTop-troy"), "mouseout",
		function() {
			$("goTop-troy").style.background = "#303030";
		});
		addEvent($("goBtn-troy"), "mouseover",
		function() {
			$("goBtn-troy").style.background = "#FF0004";
		});
		addEvent($("goBtn-troy"), "mouseout",
		function() {
			$("goBtn-troy").style.background = "#303030";
		});
	};
}));