解决获取图片实际尺寸(宽高)的bug
需求:获取图片的宽高其实是为了预先做好排版样式布局做准备。
可以利用图片onload事件监听获取图片的宽高属性值。在IE9以下版本只能使用图片的width与height属性,HTMl5中新加入了naturalHeight与naturalWidth属性,用来标记图片的实际尺寸。 代码如下:
//图片地址
var imgSrc = 'https://farm4.staticflickr.com/3530/3273073729_4cc8a5c665_z.jpg?zz=1'; var img = new Image();
img.onload = function(){
console.log('img onload'); if ( typeof img.naturalWidth != 'undefined') {
originalImgW = img.naturalWidth;
originalImgH = img.naturalHeight;
console.log('natural -> ', originalImgH, '~~', originalImgW);
} else {
13 originalImgW = img.width;
14 originalImgH = img.height;
15 console.log('IE8 -> ', originalImgH, '~~', originalImgW);
}
} img.src = imgSrc;
但是,在实际项目中使用上述代码却出现了bug.
当浏览器为IE8,并且开启了IE8兼容模式后,在无缓存的情况下,img.width 与 img.height属性获取的值为0,缓存后width与height属性值正常。
在浏览器IE8,不开启IE8兼容模式,关闭浏览器缓存,上述现象几率性出现。
根据现象分析,图片如果缓存了,就可以正确获取图片的尺寸,因此是否可以在无缓存时加载两次图片,获取第二次的尺寸。
将代码更改如下:
//图片地址
var imgSrc = 'https://farm4.staticflickr.com/3530/3273073729_4cc8a5c665_z.jpg?zz=1'; var img = new Image(); img.onload = function(){
console.log('img onload'); if ( typeof img.naturalWidth != 'undefined') {
originalImgW = img.naturalWidth;
originalImgH = img.naturalHeight;
console.log('natural -> ', originalImgH, '~~', originalImgW);
} else {
var img4Fix = new Image();
img4Fix.src = imgSrc;
originalImgW = img4Fix.width;
originalImgH = img4Fix.height;
console.log('IE8 with fix -> ', originalImgH, '~~', originalImgW);
}
} img.src = imgSrc;
当img图片onload后,缓存中其实已经有了图片文件。
img4Fix 向同一个地址请求图片,浏览器判断该地址已经存在缓存中,则不再向服务器发送请求,是从缓存中获取图片,获取的缓存图片的尺寸是正确的。
由于第二次请求同一个图片不再向服务器发送请求,所以也无需再监听img4Fix的onload事件。
解决获取图片实际尺寸(宽高)的bug的更多相关文章
- js判断图片加载完成后获取图片实际宽高
通常,我们会用jq的.width()/.height()方法获取图片的宽度/高度或者用js的.offsetwidth/.offsetheight方法来获取图片的宽度/高度,但这些方法在我们通过样式设置 ...
- RT/Metro商店应用如何如何获取图片的宽高
RT/Metro商店应用如何如何获取图片的宽高 var file = await StorageFile.GetFileFromApplicationUriAsync(new Uri("ms ...
- JS获取图片实际宽高及根据图片大小进行自适应
JS获取图片实际宽高,以及根据图片大小进行自适应 <img src="http://xxx.jpg" id="imgs" onload="ad ...
- JS获取图片实际宽高
JS获取图片实际宽高,以及根据图片大小进行自适应 <img src="http://xxx.jpg" id="imgs" onload="ada ...
- 根据图片url地址获取图片的宽高
/** * 根据img获取图片的宽高 * @param img 图片地址 * @return 图片的对象,对象中图片的真实宽高 */ public BufferedImage getBufferedI ...
- Js获取图片原始宽高
如果我们页面看到的图片都是缩略图,那就需要做个图片点击放大效果,那么怎样获取图片的原始宽高呢?方法如下: //获取图片原始宽度 function getNaturalWidthAndHeight(im ...
- Android 获取图片真实宽高
Resources res = mContext.getResources(); BitmapFactory.Options opts = new BitmapFactory.Options(); o ...
- UIImageView 获取图片的 宽 高
该文章纯属这两天开发的经验之谈 并且也是平常没注意 这回发现的一个小方法 并且很实用 在开发中 提高了很大的效率 更加符合高保真的要求 通常 美术 切的一些图片 需要 :1还原的 现在 我们一般支持i ...
- html5获取图片的宽高
var fr = new FileReader; fr.readAsDataURL($("#inputFileId").files[0]); fr.onload = functio ...
随机推荐
- 开发系统级应用不被Kill
一.设置方法 (1) 在AndroidManifest中application根节点下,添加如下代码: android:persistent="true" (2) 将应用程序pus ...
- [存一下]iptables模块
介绍地址: http://www.tummy.com/blogs/2005/07/17/some-iptables-modules-you-probably-dont-know-about/ [1] ...
- bzoj [POI2007]旅游景点atr 状态压缩+Dij
[POI2007]旅游景点atr Time Limit: 30 Sec Memory Limit: 357 MBSubmit: 2258 Solved: 595[Submit][Status][D ...
- NYOJ 832 DP
合并游戏 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 大家都知道Yougth除了热爱编程之外,他还有一个爱好就是喜欢玩. 某天在河边玩耍的时候,他发现了一种神奇的 ...
- Java nio和io
当学习了Java NIO和IO的API后,一个问题马上涌入脑海: 我应该何时使用IO,何时使用NIO呢?在本文中,我会尽量清晰地解析Java NIO和IO的差异.它们的使用场景,以及它们如何影响您的代 ...
- 51Nod 1344 走格子 | 贪心
Input示例 5 1 -2 -1 3 4 Output示例 2 贪心 #include <bits/stdc++.h> using namespace std; typedef long ...
- HDU 5869 Different GCD Subarray Query 树状数组+离线
Problem Description This is a simple problem. The teacher gives Bob a list of problems about GCD (Gr ...
- Doc常用命令
1. 获取目录: dir 2. 清屏: cls
- CSUST选拔赛题解
本鶸鸡于本月10号参加了蔽校的选拔赛,成绩差的死,大部分的题都是赛后花了好长时间才补出来的,其中有些题还是靠QAQorz大佬帮忙才能解决,感谢Qls对我的帮助~接下来就附带上我的暴力题解,大佬们有更好 ...
- SpringCloud Feign重试详解
摘要: 今天在生产环境发生了数据库进程卡死的现象,除了sql因为全量更新,没加索引的原因,最主要还是我们的接口的服务器端接口出现问题了.忽视了更新接口的幂等性,以及调用方feign client的重试 ...