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
};
};
声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至201542412@QQ.com举报,一经查实,本站将立刻删除。
相关推荐
-
jQuery实现的元素抖动插件
本章节分享一个插件,它实现了元素抖动效果。插件的优点就是调用方便,并且可以随意设置参数。代码实例如下:
-
js实现图片懒加载的方法代码优化版
js实现图片懒加载的方法代码优化版.支持图片底部高度。
-
帝国CMS灵动标签调用tag和搜索关键字方法代码
帝国CMS灵动标签调用g和搜索关键字方法代码
-
帝国CMS内容页附件中文显示或者显示代码名称下载的方法!
国CMS模板网制作,其实本身是很简单的,就是花点时间撸代码而已,但是遇到一些奇葩的客户,有一些奇葩的需求,那么久难说了,例如下面这个
-
帝国CMS灵动标签使用esub/substr截取前后字符文字方法
帝国CMS怎么用灵动标签使用sub/substr截取前面,或者截取后面两个字符或者多个字符呢?其实方法也不难,下面帝国CMS模板网就来告诉大家如何设置: