zoukankan      html  css  js  c++  java
  • JS Img对象获取图片高度宽度(兼容Chrome)

    一般获取图片高度宽度的写法:

    var img = new Image();
    img.src = imgsrc;
    var imgWH = CalcImgTiple(img.width, img.height);

    但chrome中测试 无法获取到。img.width, img.height都为0

    原因:当图片不是本地图片,而是网络图片

    onload 在成功地装载了图像时调用的事件处理程序。

    在做web开发,其中有一个需求:利用Javascript获取要加载的图片的尺寸,所以很自然的,想到了img的onload方法,在firefox下开发完成后,到IE下调试,发现img的onload事件很多情况下都不被调用。

    最初的代码如下:

    var img = new Image;    

    img.src = "test.gif";    

    img.onload = function(){        

    alert ( img.width );    

    };

    这段代码看着没什么问题,但是为什么onload没有被IE调用呢?因为IE会缓存图片,第2次加载的图片,不是从服务器上传过来的,而是从缓冲区里加载的。是不是从缓冲区里加载的图片就不触发onload事件呢?我于是我测试了以下代码,成功了~

    var img = new Image;    

    img.onload = function(){        

    alert ( img.width );     };    

    img.src = "test.gif";

    把onload写到前面去,先告诉浏览器如何处理这张图片,再指定这张图片的源,这样就正常了。所以,不是IE没有触发onload事件,而是因为加载缓冲区的速度太快,以至于没有运行到img.onload的时候,onload事件已经触发了。这让想到了Ajax,在写xmlhttp的时候,都是先指定onstatechange的回调函数,然后再send数据的,道理是一样的

  • 相关阅读:
    关于Maven项目的pom.xml中的依赖或插件失效的解决方法
    java引用数据类型在方法中的值传递
    java匹配http或https的url的正则表达式20180912
    java正则表达式的进阶使用20180912
    java线程池 多线程 搜索包含关键字的文件路径
    魔术球问题
    [SDOI2009]晨跑
    [洛谷P2045]方格取数加强版
    最小路径覆盖问题
    最长不下降子序列问题
  • 原文地址:https://www.cnblogs.com/shikyoh/p/3406192.html
Copyright © 2011-2022 走看看