jQuery.position()方法获取值为0解决方案

我心飞翔 分类:实例代码

关于此方法的基本用法这里就不介绍了,具体用法可以参阅jQuery 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
  };
};

回复

我来回复
  • 暂无回复内容