JS 滚动事件window.onscroll与position:fixed写兼容IE6的

网络编程 2021-07-04 20:00www.168986.cn编程入门
这篇文章主要介绍了JS 滚动事件window.onscroll与positionfixed写兼容IE6的回到顶部组件的相关资料,需要的朋友可以参考下

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

狼蚁网站SEO优化具体说说如何利用JavaScript中的滚动事件window.onscroll实现这个回到顶部组件。具体效果如下

IE6


IE8


FireFox


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

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

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

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://.w3./TR/html4/strict.dtd">
<html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
 <title>回到顶部</title>
 <style type="text/css">
 #_div{
 position:fixed;
 bottom:0px;
 right:0px;
 display:none;
 /兼容IE6的position:fixed/
 _position: absolute;     
 _: 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_" name="page_"></a><!--回到顶部的锚点-->
 <div id="_div"><a href="#page_" 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 _div = document.getElementById("_div");
  if (t >= 300) {
   _div.style.display = "inline";
  }
  else {
   _div.style.display = "none";
  }
 }
</script>

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

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

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by