兼容IE,firefox,chrome,safari预加载图片height和width获取

在web开发中我们有时需要通过js去预加载图片,按照平常的写法: 

var img=new Image(); 
img.src="xxxx图片路径"; 
然后alert(img.height); 
这种写法在chrome上就不适用了,在chrome中弹出0. 
为了修正这种异常可以采用下面的写法 

function loadImage(url) { 
    var img = new Image(); 
    img.src = url; 
    if (img.complete) { 
        alert(img.width); 
        return; 
    } 

    img.onload = function () { 
        callback.call(img); 
           alert(this.height); 
    }; 
}; 
这种写法就可以解决这个这一问题了。 
jquery写法 
$("img").load(function(){ 
if (this.complete||this.readyState=="complete") { 
        $(this).css({"margin-left":(120-this.width)/2,"margin-top":(80-this.height)/2}); 
        return; 
    } 
})
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值