javascript 缓动返回顶部案例
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>document</title>
<style media="screen">
img {
position: fixed;
bottom: 100px;
right: 50px;
cursor: pointer;
display: none;
border: 1px solid #ddd;
}
div {
width: 800px;
margin: 80px auto;
font: 500 18px/1.5 "simSun";
color: darkorange;
}
</style>
</head>
<body>
<img src="data:images/Top.jpg" alt="">
<div>
Lorem ipsum dolor sit amet, consectetur adipisicing elit. Ipsa porro numquam modi. Nulla, in maxime numquam iure debitis consequatur quasi quae consequuntur vitae omnis, commodi rem quibusdam quisquam dolores quo ut ipsam. Doloremque aliquam ipsum vero tenetur cumque eveniet quo cupiditate et ullam eum mollitia cum, eos aspernatur dicta accusamus, fugit deserunt fuga, veritatis natus in ratione voluptas, laboriosam facilis! Similique debitis, repellendus corrupti perspiciatis cum accusantium maxime nam facere architecto quasi aut quod, iusto dignissimos cumque necessitatibus! Accusantium culpa,
<br>
<br> adipisci natus quas quae quia tempore perspiciatis dolorem ut explicabo sequi, sit! Ab ducimus placeat expedita iusto maiores vel animi, quasi id rem omnis dolorum tenetur explicabo veritatis. Praesentium ullam, architecto veniam voluptatibus molestias doloribus sed aperiam ipsam iusto cum nisi vero nostrum officia quae, sit hic commodi! Modi laborum porro hic provident tempora. Error libero itaque vitae molestias dolore tempore repellat sed cum voluptate explicabo officiis aliquid, vero modi, possimus fugit ipsam reiciendis minima. Saepe asperiores fugiat pariatur, vero beatae, blanditiis. Aliquid consequuntur omnis minima voluptas obcaecati mollitia odio eum ex repellendus rerum, laboriosam molestias,
<br>
<br> veniam, aliquam dolorum! Vel eaque, modi vero autem molestias doloribus quae facere, accusamus enim atque amet. Commodi, saepe temporibus quaerat veritatis omnis, nemo facere odit beatae iusto doloremque consequatur odio harum! Facere dolores provident cum, corporis iure nulla nostrum dolorum minus in quaerat laboriosam vero sequi delectus quos perferendis maxime quas, consectetur quis aliquam illo et temporibus. Temporibus veritatis sequi, mollitia rem eveniet repellat quos in nulla! Deleniti magni fugitbr
<br>
<br>dicta, ea debitis natus molestiae itaque nam, ab quidem enim ex optio, eaque, qui perferendis modi. Omnis in voluptate necessitatibus saepe, vero quas vitae cumque sint sequi, ad sapiente nemo illum eum quidem, rerum laudantium commodi dicta facilis veniam molestias quis maxime nisi? Dolor delectus sapiente eveniet ipsam pariatur, fuga quos rerum officia nostrum aliquam temporibus odio minus quod earum libero mollitia quas blanditiis. Minus voluptates, numquam repudiandae unde odio ducimus quaerat eligendi veniam debitis facilis esse iste saepe
<br>
<br>cum iure? Alias voluptate praesentium beatae mollitia debitis a dolorum, incidunt blanditiis maxime. Deleniti debitis quae minus eaque tempore vel eligendi a neque ad, incidunt nobis in sit obcaecati dolore. Ex earum cum distinctio fugiat eligendi adipisci, debitis atque, non eius iusto, consectetur magnam sapiente quo repellendus. Natus in itaque possimus eos, repudiandae debitis necessitatibus vero facere eveniet animi, minus sint illo dicta. Odit, ad temporibus non laboriosam, error maiores earum reprehenderit illo nisi vel est fugiat magni eius tempora tempore! Quaerat modi omnis est, ipsa expedita blanditiis. Voluptas qui modi nulla earum fuga perspiciatis mollitia et placeat, provident cum molestiae ab veritatis, consequatur necessitatibus sequi, nihil error quibusdam odit. Distinctio mollitia, repudiandae magni minus aliquid harum aperiam illum in? Hic, quaerat illo deserunt nihil voluptatem molestiae cupiditate, quis dolores unde aperiam minus. Aspernatur asperiores aliquam fugit non animi, dolor, perferendis delectus similique tempora? Sed ex beatae natus voluptate maiores laudantium voluptatem, quo earum praesentium repellat odit, vel fuga tenetur cum id, iure fugit sapiente repellendus
<br>
<br>perspiciatis totam. Veritatis, modi consequuntur dolore vero repudiandae distinctio sit maxime sapiente. Quisquam tempora laborum sed excepturi natus debitis porro corrupti cum voluptatem vitae, odit, officia ullam illo officiis odio consequatur expedita possimus! Dicta placeat nulla numquam hic itaque molestiae asperiores assumenda similique id eos vero earum, ea fugiat esse blanditiis excepturi obcaecati sequi! Sapiente est, nostrum non saepe, facere velit placeat voluptas, sit molestiae rem soluta
<br>
<br>iure itaque illum! Rem repellendus, explicabo asperiores accusantium, deleniti aperiam accusamus reiciendis alias dolore modi ipsum beatae dolor praesentium. Maiores amet molestias pariatur in animi ipsa nobis deleniti nulla voluptatum rerum sapiente culpa minima reiciendis voluptatem, nam, impedit fuga, esse delectus enim repellat, laboriosam quod sunt repellendus! Pariatur perferendis voluptates
<br>
<br>error rem non, ullam laudantium? Quidem nisi quos debitis, unde obcaecati cumque animi autem atque facere neque incidunt itaque esse error harum asperiores fuga distinctio culpa. Reprehenderit minus deserunt nobis repellendus et provident, inventore commodi sed laudantium! Saepe inventore vel mollitia maiores eum dolor quia esse, facilis magni, exercitationem suscipit, vero magnam qui aut culpa molestias neque porro.
</div> <script type="text/javascript">
var img = document.getElementsByTagName("img")[0];
window.onscroll = function(){
//被卷去的距离>200,显示返回顶部图标
//否则隐藏
if (scroll().top > 1000) {
img.style.display = "block";
}else {
img.style.display = "none";
} //每次移动滚动条的时候都给leader赋值,模拟leader获取顶部的距离
leader = scroll().top;
}
//缓动跳转到页面最顶端
var timer = null;
var target = 0; //目标位置
var leader = 0; //显示区域自身的位置 img.onclick = function(){
//技术点:window.scrollTo(0,0)
//要用定时器,先清定时器
clearInterval(timer);
timer = setInterval(function(){
//获取步长
var step = (target - leader) / 10;
//二次处理步长
step = step > 0 ? Math.ceil(step) : Math.floor(step);
leader = leader + step;
//显示区域移动
window.scrollTo(0,leader);
//window.scrollTo(x,y); x:横向滚动条的坐标; y:纵向滚动条的坐标;
//清除定时器
if (leader === 0) {
clearInterval(timer);
}
},30);
} function scroll(){ //开始封装要用的scrollTop
if (window.pageYOffset != null) {
//因为window.pageYOffset的默认值是0,所以需要判断
return {
left: window.pageXOffset,
top: window.pageYOffset
}
}else if (document.compatMode === "CSS1Compat") {
//标准浏览器,来判断有没有声明DTD
return {
left: document.documentElement.scrollLeft,
top: document.documentElement.scrollTop
}
}
return {
//未声明DDTD
left: document.body.scrollLeft,
top: document.body.scrollTop
}
}
</script>
</body>
</html>
javascript 缓动返回顶部案例的更多相关文章
- jQuery---小火箭返回顶部案例
小火箭返回顶部案例 1. 滚动页面,当页面距离顶部超出1000px,显示小火箭. 封装在scroll函数里,当前页面距离顶部为$(window).scrollTop >=1000 小火箭显示和隐 ...
- JS——BOM操作(点击按钮返回顶部案例:scrollTop的用法)
点击按钮返回顶部案例: 代码如下: <!DOCTYPE html> <html lang="en"> <head> <meta chars ...
- JavaScript 缓动效果
Math.easeout = function (A, B, rate, callback) { if (A == B || typeof A != 'number') { return; } B = ...
- javascript+JQuery实现返回顶部功能
很多网站上都有返回顶部的效果,本文阐述如何使用jquery实现返回顶部按钮. 首先需要在顶部添加如下html元素: <p id="back-to-top"><a ...
- 【JavaScript&jQuery】返回顶部
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- javascript实现网页返回顶部功能
在浏览网页时,我们一般是拖动滚动条向下滑动,浏览下面的内容,当页面超过单页时,右下角会出现一个回到顶部的图标,有些网站这个图标一直显示在右下角的. 有些网站使用锚链接来实现页面内容的跳转,但这种效果的 ...
- JavaScript实现减速返回顶部
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- js网页返回顶部和楼层跳跃的实现原理
这是简单的效果图. (实现楼层间的跳跃,主要依靠的是 window.scrollTo(x,y)方法 ,将浏览器的可见区域移动到指定的x,y坐标上.) 说楼层跳跃前,先温习下,一般网页在高度较大时, ...
- 渲染优化 之fixed与返回顶部 以及开启GPU Hack
fixed元素,常见网站右侧出现一个返回顶部的按钮,滚动的时候,会发现返回顶部这个区域在不停的进行重绘,而返回顶部是position:fixed定位的.这也解释了为什么fixed定位是最耗性能的属性之 ...
随机推荐
- Mysql 5.7.21 单机多实例安装
下载MySQL 5.7 二制包 [root@MySQL ~]# wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.21-linu ...
- node的cookie-parser和express-session
let express = require('express'); let cookieParser = require('cookie-parser'); let expressSession = ...
- GSP事件探查器 无法进行跟踪的解决办法(场景之一)
使用GSP事件探查器 可以快速的定位问题, 跟踪效果很好 但是有时会出现 无法新建跟踪的问题. 这里有一个比较常见的解决办法 问题现象: 新建跟踪无效. 解决办法 其实就三步: 1. 打开 servi ...
- python3_列表、元组、集合、字典
列表list #列表的基本操作 >>> a=[] #创建空列表 >>> a = [0,1,2,3,4,5] #创建列表并初始化,列表是[]包含由逗号分隔的多个元素组 ...
- ubuntu解压zip文件
step1 # 安装解压软件 sudo apt-get install unzip step # 2 解压文件 unzip xxxxx.zip
- GlusterFs卷的简单操作
一.创建卷 gluster volume create 例子:gluster volume create gv0 replica 2 server1:/data/brick1/gv0 server2: ...
- js & float number bug
js & float number bug 前端最好不要处理任何的 float number 的计算/精确度转换的操作,不热很容易丢失精度,显示错误! 前端显示个 0.0 都很费劲,最好的方式 ...
- Dictionary CPU 100%
昨天服务器的CPU突然100%,此服务已经运行几年了,都平安无事.既然问题出现当然要找出这个遗留多年的小概率问题.出现cpu 100% 一般就是哪里出现了无法跳出的死循环. 1.获取进程的内存信息 服 ...
- php-编译模块2
PHP扩展-扩展的生成和编译 首先说明一下,PHP扩展有两种编译方式:方式一:在编译PHP时直接将扩展编译进去方式二:扩展被编译成.so文件,在php.ini里配置加载路径: 以下开始说明创建PHP扩 ...
- BZOJ1500[NOI2005]维修数列——非旋转treap
题目描述 请写一个程序,要求维护一个数列,支持以下 6 种操作: 请注意,格式栏 中的下划线‘ _ ’表示实际输入文件中的空格 输入 输入的第1 行包含两个数N 和M(M ≤20 000),N 表示初 ...