jQuery.position()方法获取不到值的安全替换方法

 更新时间:2015年03月13日 09:42:22   投稿:junjie  
这篇文章主要介绍了jQuery.position()方法获取不到值的安全替换方法,本文给出了一种变通的方法,用.offset()来换算,需要的朋友可以参考下

调用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
    };
};


这虽然产生了多余的代码,但比较可靠的多,用的让人放心。

相关文章

  • jQuery插件HighCharts绘制简单2D柱状图效果示例【附demo源码】

    jQuery插件HighCharts绘制简单2D柱状图效果示例【附demo源码】

    这篇文章主要介绍了jQuery插件HighCharts绘制简单2D柱状图效果,结合完整实例形式分析了jQuery使用HighCharts插件绘制2D柱状图的实现步骤与相关操作技巧,并附带demo源码供读者下载参考,需要的朋友可以参考下
    2017-03-03
  • jquery tmpl模板(实例讲解)

    jquery tmpl模板(实例讲解)

    下面小编就为大家带来一篇jquery tmpl模板(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • jquery tablesorter.js 支持中文表格排序改进

    jquery tablesorter.js 支持中文表格排序改进

    之前研究过一下表格排序。上网找了一些代码研究了一下。勉强做了一个用着。后面发现当动态给单元格加超链接,或者列中存在一些空白,就排序不了了。
    2009-12-12
  • jquery实现简单的全选和反选功能

    jquery实现简单的全选和反选功能

    我们在做项目的时候,经常需要实现全选和反选功能,到网上搜了一圈,发现网上写的全选的代码,不是完整的,是有bug的。下面结合自己的项目给大家分享下。
    2016-01-01
  • JQuery点击行tr实现checkBox选中的简单实例

    JQuery点击行tr实现checkBox选中的简单实例

    下面小编就为大家带来一篇JQuery点击行tr实现checkBox选中的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-05-05
  • qTip2 精致的基于jQuery提示信息插件

    qTip2 精致的基于jQuery提示信息插件

    qTip2是一个灰常强大且精致的jQuery提示信息插件,是qTip的第2版,也是一个全新的版本,提供了丰富的功能及漂亮的外观,非常易于使用
    2012-02-02
  • jquery下操作HTML控件的实现代码

    jquery下操作HTML控件的实现代码

    jquery 的操作HTML控件,需要的朋友可以参考下。
    2010-01-01
  • 2010年最佳jQuery插件整理

    2010年最佳jQuery插件整理

    在前两周国外知名博客WDL先后分享了“2010最佳系列”中的“最佳免费WordPress主题”和“最佳免费字体”,在这个星期又发布了2010年最佳jQuery插件。
    2010-12-12
  • dul无法加载bootstrap实现unload table/user恢复

    dul无法加载bootstrap实现unload table/user恢复

    这篇文章主要介绍了dul无法加载bootstrap实现unload table/user恢复的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-09-09
  • 合并table相同单元格的jquery插件分享(很精简)

    合并table相同单元格的jquery插件分享(很精简)

    正好项目中有个小需求, 要求把表格指定列中内容相同的单元格进行合并,本质上涉及的就是td的rowspan属性, 数出含相同内容单元格的个数, 然后给第一个与上一行内容不同的td其rowspan属性附上正确的值即可, 为了能直观的理解
    2011-06-06

最新评论