jQuery.position()方法获取不到值的安全替换方法
调用jQuery.position()方法会返回相对于父元素的位置,jQuery官方文档中描述说,它跟.offset()方法不一样,.offset()返回的是相对于document的位置,而.position()返回的是相对于父元素的位置。
但事实上,在使用的过程中,我们发现.position()返回的值经常是0。但事实不是0。尤其是谷歌浏览器和IE浏览器里。火狐浏览器没有此问题。
究其原因,以基于Webkit的浏览器(谷歌浏览器和Safari浏览器)为例,只有当元素(图片、flash等)完全加载后,浏览器才能访问到这些元素的高度和宽度,而火狐浏览器是在DOM加载完成后就能访问这些属性,它不需要知道这个元素的完整尺寸。而谷歌浏览器就不行。因此在谷歌/IE这样的浏览器里,如果你想使用.position()获取元素的偏移量,往往得到值就是初始值:0。
有一种补救的方法是将你的.position()调用放到$(window).load()事件触发之后,而不是$(document).ready事件之后。但这种方法也未必可靠。
另外一种变通的方法是用.offset()来换算:
jQuery.fn.aPosition=function(){
thisLeft=this.offset().left;
thisTop=this.offset().top;
thisParent=this.parent();
parentLeft=thisParent.offset().left; parentTop=thisParent.offset().top;
return{ left:thisLeft-parentLeft, top:thisTop-parentTop }; };
热门推荐
10 情侣祝福语古文简短独特
11 酒店伴娘祝福语简短
12 晚上甜蜜的祝福语简短
13 给新娘简短的祝福语
14 当爸爸的简短祝福语
15 洛宁新年祝福语大全简短
16 新年祝福语简短搞笑幽默
17 结婚祝福语大全简短霸气
18 新人结婚祝福语简短高端