js 获取远程图片大小(判断上传图片大小)

本文介绍了一个使用JavaScript实现的函数,用于获取图片的宽度和高度。该函数能够处理不同类型的图片源,并在非IE浏览器中正确触发加载完成事件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

function getImageSize(cfg){

    var img=document.createElement('img');
        callback=cfg.oncomplete;

    img.src = typeof cfg.img == 'string'?cfg.img:cfg.img.src;

    img.setAttribute('style','position:absolute;dispaly:none;');

    document.body.appendChild(img);	
	if(!+[1,]){//判断是否为IE浏览器
		if(img.complete){
			
			callback.call({"width":img.width,"height":img.height},null);
			BB_removeElement(img);
		}
	}
			img.οnlοad=img.οnerrοr=img.onreadystatechange=function(){	
				   if(img&&img.readyState&&img.readyState!='loaded'&&img.readyState!='complete'){			
					   return false;
					}
				img.onload = img.onreadystatechange = img.onerror = null;
				callback.call({"width":img.width,"height":img.height},null);
				  img.parentNode.removeChild(img);
				img=null;
			};
注:在非IE浏览器下,即使是缓存的图片载入也有onload触发。而在IE下却没有,所以用complete属性。

 调用方法:
getImageSize({
		img:''//(图片的url)
		oncomplete:function(){
                     alert('宽度:'+this.width+','+'高度:'+this.height);
              });


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值