在前端中有许多时候希望显示图片的的真实大小的场景(如果图片预览这样的场景),如果直接用选择器把html中的img元素选择出来然后输出他的width()和height()的话,如果对img元素有做样式限定的则输出的是样式中的高度和宽度,无法得出图片的真实像素大小。这里可采用新建个图片对象,然后直接载入(这里可以用load载入)整个图片然后在或者其高宽属性即可。

如以下demo代码

$(document).ready(function(){$("img").each(function(){//获取所有img元素,进行遍历$("<img/>").attr("src",this.src).on("load",function(){//这里使用的jquery新建一个img对象进行添加attr属性,把src添加上去,然后进行载入事件varimgw=this.width;//这里的width和height就是图片实际的宽高了varimgh=this.height;alert("imgw:"+imgw+','+"imgh:"+imgh);});});});