AutoCAD 3DMAX C语言 Pro/E UG JAVA编程 PHP编程 Maya动画 Matlab应用 Android
Photoshop Word Excel flash VB编程 VC编程 Coreldraw SolidWorks A Designer Unity3D
 首页 > JavaScript

js判断图片加载完成后获取图片实际宽高的方法

51自学网 http://www.wanshiok.com
js,判断图片加载,获取图片宽高

本文实例讲述了js判断图片加载完成后获取图片实际宽高的方法。分享给大家供大家参考,具体如下:

通常,我们会用jq的.width()/.height()方法获取图片的宽度/高度或者用js的.offsetwidth/.offsetheight方法来获取图片的宽度/高度,但这些方法在我们通过样式设置了图片的宽高后获取的就不是图片的实际宽高,这显然在有些时候不是我们想要的结果,那么有没有一种方法来获取这样的实际宽高呢?答案是有的。下面的代码就能解决这样的问题:

<img src="01.jpg" id="test" width="250px">

js code:

//图片加载完成后获取图片实际宽高var _test = document.getElementById("test");test.onload = function(){  imgSize.call(_test);}function imgSize(){  var imgObj = new Image();  imgObj.src = this.src;  alert(imgObj.width + "/n" + imgObj.height);}

如果想在其他方法中调用这个实际的宽高,应该将alert(imgObj.width + "/n" + imgObj.height);改为return imgObj,然后是调用的方法:

window.onload = function(){    function a(){      var real= imgSize.call(_test);      var realwidth = real.width;      alert(realwidth);    }    a();}

以上方法过于繁琐,经过本人的提炼,简写如下:

window.onload = function(){    var _test = document.getElementById("test"); //若是jq,则直接将此代码换成 var _test = $("#test"); 即可。    var imgObj = new Image();    imgObj.src = _test.src; //若是jq,则直接将此代码换成 imgObj.src = _test.attr("src"); 即可。    alert(imgObj.width);}

这样,就可以在其他方法里直接调用图片的实际宽高了。

更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结

希望本文所述对大家JavaScript程序设计有所帮助。


js,判断图片加载,获取图片宽高  
上一篇:jquery插件jquery.dragscale.js实现拖拽改变元素大小的方法(附demo源码下载)  下一篇:JS面向对象(3)之Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法