小知识点,废话不多说,直接上代码
css:
复制代码 代码如下:
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:
复制代码 代码如下:
在window.onscroll上即可添加滚动条滚动事件,在监听函数中的top=document.documentelement.scrolltop||document.body.scrolltop;之所以这么写,就是避免不同浏览器的兼容性,这里我测试了chrom和ff浏览器,前者支持document.body.scrolltop这个属性,后者支持另一个属性,因此可以用‘||'符号糅合这两个属性,兼容不同浏览器。anchortop就是目标的开始与浏览器顶部的距离,这里还需要注意的是'#anchor‘这个标签的position:absulate,否则top属性值总是是0px。
当滚动条滚动时,top值变化,随后将'#anchor'的初始top值加上滚动条的top值,即可保持内容始终处于同一位置。