zoukankan      html  css  js  c++  java
  • 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 + "
    " + imgObj.height);
    }

    如果想在其他方法中调用这个实际的宽高,应该将alert(imgObj.width + " " + 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);
        }

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

    本文出自:http://www.51xuediannao.com/qd63/index.php/page-2-71-1.html  感谢!

  • 相关阅读:
    P2910 [USACO08OPEN]寻宝之路Clear And Present Danger 洛谷
    P2212 [USACO14MAR]浇地Watering the Fields 洛谷
    Python字体颜色设置
    Python小游戏 -- 猜数字
    数据结构 -- 链表&双向链表
    数据结构 -- 队列 & 循环队列 -- 数组实现
    数据结构 -- 栈的数组实现法
    洛谷P1036 选数
    如何让c语言使用结构体近似模拟c++中的类
    对c语言回调函数的理解
  • 原文地址:https://www.cnblogs.com/tnnyang/p/4815995.html
Copyright © 2011-2022 走看看