jQuery.position()方法获取不到值的安全替换方法
作者:bea
调用jQuery.position()方法会返回相对于父元素的位置,jQuery官方文档中描述说,它跟.offset()方法不一样,.offset()返回的是相对于document的位置,而.position()返回的是相对于父元素的位置。 但事实上,在使用的过程中,我们发现.position()返回的值经常是0。但事实不是0。尤其是谷歌浏览器和IE浏览器里。火狐浏览器没有此问题。 究其原因,以基于Webkit的浏览器(谷歌浏览器和Safari浏览器)为例,只有当元素(图片、
调用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 }; };
这虽然产生了多余的代码,但比较可靠的多,用的让人放心。
有用 | 无用
但事实上,在使用的过程中,我们发现.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 }; };
这虽然产生了多余的代码,但比较可靠的多,用的让人放心。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- 纯javascript实现简单下拉刷新功能
- Jquery插件实现点击获取验证码后60秒内禁止重新获取
- node.js [superAgent] 请求使用示例
- JavaScript中逗号运算符介绍及使用示例
- JavaScript原生对象之String对象的属性和方法详解
- JQuery报错Uncaught TypeError: Illegal invocation的处理方法
- JavaScript原生对象之Number对象的属性和方法详解
- JavaScript原生对象之Date对象的属性和方法详解
- innerHTML属性,outerHTML属性,textContent属性,innerText属性区别详解
- JavaScript内存管理介绍
- JavaScript中的this关键字使用方法总结
- javascript中slice(),splice(),split(),substring(),substr()使用方法
- 在linux中使用包管理器安装node.js
- JQuery中serialize() 序列化
- JavaScript中通过prototype属性共享属性和方法的技巧实例
- JQuery中$.each 和$(selector).each()的区别详解
- JavaScript实现判断图片是否加载完成的3种方法整理
- JavaScript检查弹出窗口是否被阻拦的方法技巧
- JavaScript中常用的六种互动方法示例