JS 图片上传兼容性问题(获取图片宽高兼容)

本文介绍了一种解决360安全浏览器极速模式下图片加载异常的方法。通过调整图片加载逻辑,使用onload事件确保图片尺寸正确获取,避免了因浏览器缓存导致的问题。

原代码(360安全浏览器的极速模式不兼容)

1
2
3
4
5
function ImgAuto(i, MaxW, MaxH) {
    var o = new Image();
    o.src = i.src;
    var w = o.width;//w等于null,别的浏览器未出现该问题

图片需要重新再加载一遍

1
2
3
4
5
6
7
function ImgAuto(i, MaxW, MaxH) {
    var o = new Image();
    o.onload = function(){        
        var w = o.width;
    
    o.src = i.src;

注:

    把onload写到前面去,先告诉浏览器如何处理这张图片,再指定这张图片的源,这样是为了避免IE兼容性问题。

    IE会缓存图片,第2次加载的图片,不是从服务器上传过来的,而是从缓冲区里加载的,不是IE没有触发onload事件,而是因为加载缓冲区的速度太快,以至于没有运行到img.onload的时候,onload事件已经触发了。这让我想到了Ajax,在写xmlhttp的时候,都是先指定onstatechange的回调函数,然后再send数据的,道理是一样的。










本文转自 艺晨光 51CTO博客,原文链接:http://blog.51cto.com/ycgit/1707144,如需转载请自行联系原作者
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值