JS 滚动事件window.onscroll与position:fixed写兼容IE6的回到顶部组件


Posted in Javascript onOctober 10, 2016

现在网上的回到顶部组件,懂不懂就一大段让人看不懂javascript代码,还各种不兼容。起始这个组件,完全可以自己利用javascript的滚动事件window.onscroll与position:fixed手写。IE6的兼容性问题主要出现在position:fixed上面,如何解决已经在《【CSS】IE6中的position:fixed问题与随滚动条滚动的效果》(点击打开链接)介绍过了。

下面具体说说如何利用JavaScript中的滚动事件window.onscroll实现这个回到顶部组件。具体效果如下:

IE6:

JS 滚动事件window.onscroll与position:fixed写兼容IE6的回到顶部组件

IE8:

JS 滚动事件window.onscroll与position:fixed写兼容IE6的回到顶部组件

FireFox:

JS 滚动事件window.onscroll与position:fixed写兼容IE6的回到顶部组件

首先是HTML+CSS的布局,在页面的最顶部布置一个id与name皆为page_top的<a></a>作为锚点,之所以要共同设置id与name一切为了兼容。

然后就是在右下角放一个position:fixed的,内容为↑的div,当然你想搞得炫一点可以弄成一张图片,甚至搞成♂也可以,这个div一开始是隐藏的。

最后是一大堆没有意义的、占位置的<p>,没什么好说的。

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
 <title>回到顶部</title>
 <style type="text/css">
 #top_div{
 position:fixed;
 bottom:0px;
 right:0px;
 display:none;
 /*兼容IE6的position:fixed*/
 _position: absolute;     
 _top: expression(eval( 
 document.documentElement.scrollTop + document.documentElement.clientHeight-this.offsetHeight- 
 (parseInt(this.currentStyle.marginTop,10)||0)- 
 (parseInt(this.currentStyle.marginBottom,10)||0))); 
 _margin-bottom:0px;
 _margin_right:0px;
 }
 </style>
 </head>
 <body>
 <a id="page_top" name="page_top"></a><!--回到顶部的锚点-->
 <div id="top_div"><a href="#page_top" style="text-decoration:none">↑</a></div>
 <p>占位置的内容</p><p>占位置的内容</p><p>占位置的内容</p><p>占位置的内容</p><p>占位置的内容</p>
 <p>占位置的内容</p><p>占位置的内容</p><p>占位置的内容</p><p>占位置的内容</p><p>占位置的内容</p>
 <p>占位置的内容</p><p>占位置的内容</p><p>占位置的内容</p><p>占位置的内容</p><p>占位置的内容</p>
 <p>占位置的内容</p><p>占位置的内容</p><p>占位置的内容</p><p>占位置的内容</p><p>占位置的内容</p>
 <p>占位置的内容</p><p>占位置的内容</p><p>占位置的内容</p><p>占位置的内容</p><p>占位置的内容</p>
 </body>
</html>

之后的脚本部分,一切很明朗了:

<script type="text/javascript">
 window.onscroll = function(){
  var t = document.documentElement.scrollTop || document.body.scrollTop;
  var top_div = document.getElementById("top_div");
  if (t >= 300) {
   top_div.style.display = "inline";
  }
  else {
   top_div.style.display = "none";
  }
 }
</script>

仅有一个滚动事件window.onscroll,就是用户滚动滚动条就会触发这个时事件,var t = document.documentElement.scrollTop || document.body.scrollTop;能够兼容绝大部分浏览器,下面的t>=300是滚动条下滚300px之后,让top_div显示,这里用inline是以免block,会影响其它样式。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
jquery text()要注意啦
Oct 30 Javascript
jquery入门——事件机制之事件中的冒泡现象示例解释
Sep 12 Javascript
JS简单的图片放大缩小的两种方法
Nov 11 Javascript
javascript随机显示背景图片的方法
Jun 18 Javascript
javascript图片预加载实例分析
Jul 16 Javascript
微信+angularJS的SPA应用中用router进行页面跳转,jssdk校验失败问题解决
Sep 09 Javascript
纯JS实现表单验证实例
Dec 24 Javascript
原生JS实现DOM加载完成马上执行JS代码的方法
Sep 07 Javascript
微信小程序中遇到的iOS兼容性问题小结
Nov 14 Javascript
详解微信小程序-canvas绘制文字实现自动换行
Apr 26 Javascript
微信小程序实现消息框弹出动画
Apr 18 Javascript
原生js实现ajax请求和JSONP跨域请求操作示例
Mar 14 Javascript
javaScript 事件绑定、事件冒泡、事件捕获和事件执行顺序整理总结
Oct 10 #Javascript
jQuery EasyUI tree 使用拖拽时遇到的错误小结
Oct 10 #Javascript
jQuery继承extend用法详解
Oct 10 #Javascript
mvc 、bootstrap 结合分布式图简单实现分页
Oct 10 #Javascript
针对后台列表table拖拽比较实用的jquery拖动排序
Oct 10 #Javascript
KnockoutJS 3.X API 第四章之数据控制流foreach绑定
Oct 10 #Javascript
KnockoutJS 3.X API 第四章之数据控制流if绑定和ifnot绑定
Oct 10 #Javascript
You might like
了解咖啡雨林联盟认证 什么是雨林认证 雨林认证是什么意思
2021/03/05 新手入门
基于php无限分类的深入理解
2013/06/02 PHP
thinkPHP删除前弹出确认框的简单实现方法
2016/05/16 PHP
php+Ajax处理xml与json格式数据的方法示例
2019/03/04 PHP
php传值和传引用的区别点总结
2019/11/19 PHP
PNG背景在不同浏览器下的应用
2009/06/22 Javascript
提高网站性能之 如何对待JavaScript
2009/10/31 Javascript
基于jQuery的淡入淡出可自动切换的幻灯插件打包下载
2010/09/15 Javascript
javascript 进阶篇1 正则表达式,cookie管理,userData
2012/03/14 Javascript
js修改table中Td的值(定义td的双击事件)
2013/01/10 Javascript
jquery 延迟执行实例介绍
2013/08/20 Javascript
jquery滚动加载数据的方法
2015/03/09 Javascript
js检测iframe是否加载完成的方法
2015/11/26 Javascript
微信小程序 网络API发起请求详解
2016/11/09 Javascript
详解nodejs实现本地上传图片并预览功能(express4.0+)
2017/06/28 NodeJs
vue实现微信二次分享以及自定义分享的示例
2019/03/20 Javascript
React生命周期原理与用法踩坑笔记
2020/04/28 Javascript
举例讲解Python程序与系统shell交互的方式
2015/04/09 Python
在Python中使用Neo4j数据库的教程
2015/04/16 Python
Python中有趣在__call__函数
2015/06/21 Python
在Django中创建URLconf相关的通用视图的方法
2015/07/20 Python
python获取当前用户的主目录路径方法(推荐)
2017/01/12 Python
Python对字符串实现去重操作的方法示例
2017/08/11 Python
简单了解Python中的几种函数
2017/11/03 Python
Python cookbook(数据结构与算法)从字典中提取子集的方法示例
2018/03/22 Python
Python操作Sql Server 2008数据库的方法详解
2018/05/17 Python
基于Python在MacOS上安装robotframework-ride
2018/12/28 Python
Python使用post及get方式提交数据的实例
2019/01/24 Python
使用python客户端访问impala的操作方式
2020/03/28 Python
澳大利亚网上玩具商店:Mr Toys Toyworld
2018/03/25 全球购物
非功能性需求都包括哪些方面
2013/10/29 面试题
护理专科毕业推荐信
2013/11/10 职场文书
授权委托书(法人单位用)
2014/09/29 职场文书
2015年事业单位工作总结
2015/04/27 职场文书
房产遗嘱范本
2015/08/06 职场文书
python前后端自定义分页器
2022/04/13 Python