我的图像已加载完毕,但其高度和宽度尚未更新什么时候发生?

如何解决我的图像已加载完毕,但其高度和宽度尚未更新什么时候发生?

| 我正在使用一个jQuery插件,该插件会在页面上的所有图片均加载完毕后调用回调。它检查
imageObject.complete
属性,并将处理程序绑定到
load
error
事件,以确定何时完成图像加载。 这很好用,但是我遇到的问题是,即使图像被认为已加载,当我检查图像或其包含
div
元素的
height
width
属性时,尺寸尚未更新。 这是一个例子: http://jsfiddle.net/RtnVx/12/ 在尝试访问
height
width
尺寸之前,如何确保已调整容纳元素的大小以适合图像? 编辑1:我清理并注释了jsfiddle中的代码,以使示例更易于理解。 编辑2:必须有一个基于缓存的竞争条件或差异,因为当我从另一台计算机上运行代码时,它可以正常工作(即,最高边距计算正确),实际上是不好的,因为它不一致。 Chrome,FWIW中的不一致现象更加明显。 另外,要明确一点,目标不是每次加载图像时都调用ѭ8。相反,应在通过AJAX
load
调用加载所有图像之后才一次调用
init
。     

解决方法

答案:http://jsfiddle.net/morrison/RtnVx/30/ 在图像加载完成之前,您无需致电ѭ11。我在加载的图像上创建了一个事件。 更新说明: 我剪出了您的jQuery插件。这太复杂了,我并不完全理解。 我当前的解决方案与插件一样,通过使用provides2ѭ事件来提供错误处理。 解决过程: 找到所有从ѭ14降序的
img
,并将该长度存储在
.data()
属性中,并存储一个变量以保持加载的数量。 在每个
img
上绑定
load
error
事件,以更新已加载图像的计数。 如果已加载/错误图像的数量达到图像总数,请致电
setTimeout()
,直到所有宽度均大于零,然后触发
init()
。     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?