js如何监听滚动条滚动事件,使得某个标签内容始终位于同一位置——w3cdream|前端学习-开发

'I'm W3cdream,创造',前·所·未·有
js如何监听滚动条滚动事件,使得某个标签内容始终位于同一位置

发布作者:萧强   发布时间:2014-03-11   阅读次数:10808

如何js如何监听滚动条滚动事件,使得某个标签内容始终位于同一位置

小知识点,废话不多说,直接上代码

CSS:


<pre name="code" class="css"><style>  
#anchor:{  
position:absulate;  
top:40%;  
left:40%;  
width:100px;  
height:100px;  
background-color:red;  
}  
</style></pre><br> 

JS:



var auchorTop = $("#anchor").css("top");  
        auchorTop = Number(auchorTop.substring(0, anchorTop.indexOf("p")));  //首先在监听器外部记录某id=anchor的标签的初始位置  
        window.onscroll = function () {  
            var top = document.documentElement.scrollTop || document.body.scrollTop;  
            $("#anchor").css("top", anchorTop + top + "px");  
        };
HTML:



<div id="anchor"></div>
在window.onscroll上即可添加滚动条滚动事件,在监听函数中的top=document.documentElement.scrollTop||document.body.scrollTop;之所以这么写,就是避免不同浏览器的兼容性,这里我测试了chrom和ff浏览器,前者支持document.body.scrollTop这个属性,后者支持另一个属性,因此可以用‘||’符号糅合这两个属性,兼容不同浏览器。anchorTop就是目标的开始与浏览器顶部的距离,这里还需要注意的是’#anchor‘这个标签的position:absulate,否则top属性值总是是0px。

当滚动条滚动时,top值变化,随后将'#anchor'的初始top值加上滚动条的top值,即可保持内容始终处于同一位置。


常用昵称:萧强,全端布道者

姓名:“刘晓强”,W3CDream创始人,目前就职于易点付。专注于web前端和移动端方面知识的研究,熟练掌握photoshop和AI,喜爱Flat UI设计和Metro UI风格,熟练掌握CSS3+HTML5技术、LESS CSS和Sass CSS,还有jQuery框架方面及一些前端框架bootstrap响应式设计等。新浪微博
友荐云推荐

前端资源

热点文章

新闻资讯

标签云

友情赞助