首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何通过innerWidth()获取插入到DOM中的对象的维数(即innerWidth)

如何通过innerWidth()获取插入到DOM中的对象的维数(即innerWidth)
EN

Stack Overflow用户
提问于 2012-03-04 12:52:20
回答 1查看 389关注 0票数 0

在一个复杂的AJAX站点上,我需要检索新插入的DOM对象的CSS维,即某个DIVs的值,这样我就可以将加载的图像调整到它们的父维度。

我将通过jQuery.load()-POST将新内容加载到DOM中:

代码语言:javascript
复制
$( 'DIV#newStuff' ).load( 'insertthis.ajax', {id:1}, function() {
    var iMaxWidth = $( 'DIV#widthNeeded' ).innerWidth();
    console.log(iMaxWidth);
} );

问题: FireFox (PaleMoon) 9.2 =>按预期返回"442“。Maxthon 3和Chrome 17 =>返回"0“或更高的值"736”。都在Win7上。jQuery 1.7.1

我还尝试了具有相同结果的jQuery.actual()-plugin。

清洁:这是一个非常简化的实际功能的摘录。我只是想展示一下核心问题。加载的脚本是普通PHP (我将扩展更改为.ajax)。

的解决方案(解决方案):用一个额外的setTimeout()-function包装成功的回调代码,可能会给一些浏览器计算新呈现的DOM元素的维度所急需的时间。

代码语言:javascript
复制
$( 'DIV#newStuff' ).load( 'insertthis.ajax', {id:1}, function() {
    setTimeout( function() {
        var iMaxWidth = $( 'DIV#widthNeeded' ).innerWidth();
        console.log(iMaxWidth);
    }, 500 );
} );
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-03-04 13:24:28

回答你修订后的问题:

我不明白你为什么会有这样的不一致。您可能需要给浏览器一段时间重新流或其他东西,方法是有效地完成以下操作:

代码语言:javascript
复制
$( 'DIV#newStuff' ).load( 'insertthis.ajax', {id:1}, function() {
    setTimeout(function() {
        var iWidth = $( 'DIV#widthNeeded' ).innerWidth();
        var jqWidthKeeper = $( 'DIV#widthKeeper' );
        var iMaxWidth = jqWidthKeeper.actual( 'innerWidth' );
        console.log(iMaxWidth);
    }, 0);
} );

jQuery在更新元素后立即调用load回调。我有时见过浏览器需要您给它们的呈现线程一点时间重新流。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9555005

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档