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數據的,道理是一樣的


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM