jQuery動態改變圖片顯示大小(修改)


Time is up. 時間快到了。  What’s new? 有什么新鮮事嗎?  Count me on 算上我。  Feel better? 好點了嗎?
 
當我們要顯示后台傳過來若干個尺寸不一的圖片時,為了保證圖片大小的一致性及比例的協調,需要動態改變圖片顯示尺寸。通過搜索,我們可以從網上找到實現此功能的jQuery代碼如下。這段代碼可以使圖片的大小保持在一定范圍內,如果圖片的原始尺寸都大於max*值,則顯示出來的圖片寬度都相等。
原始代碼:
$(document).ready(function() {
  $('.post img').each(function() {
    var maxWidth = 100; // 圖片最大寬度
    var maxHeight = 100; // 圖片最大高度
    var ratio = 0; // 縮放比例
    var width = $(this).width(); // 圖片實際寬度
    var height = $(this).height(); // 圖片實際高度

    // 檢查圖片是否超寬
    if(width > maxWidth){
      ratio = maxWidth / width; // 計算縮放比例
      $(this).css("width", maxWidth); // 設定實際顯示寬度
      height = height * ratio; // 計算等比例縮放后的高度 
      $(this).css("height", height); // 設定等比例縮放后的高度
    }

    // 檢查圖片是否超高
    if(height > maxHeight){
      ratio = maxHeight / height; // 計算縮放比例
      $(this).css("height", maxHeight); // 設定實際顯示高度
      width = width * ratio; // 計算等比例縮放后的高度
      $(this).css("width", width * ratio); // 設定等比例縮放后的高度
    }
  });
});

 

  
在我的js代碼中,也采取了這種寫法。然而在不同的瀏覽器測試效果時,發現此種寫法不能適應chrome瀏覽器(chrome版本號為10.0.648.204),會產生圖片以原有尺寸顯示出來的bug。后來把$('.post img').each()的代碼用$(window).load()方法包裝起來,就解決了chrome瀏覽器顯示不正確的問題。那么在chrome瀏覽器中為什么會產生bug,並且$(document).ready和$(window).load有什么區別呢?
 
原來document ready事件是在HTML文檔載入即DOM准備好就開始執行了,即使圖片資源還沒有加載進來。而window load事件執行的稍晚一些,它是在整個頁面包括frames, objects和images都加載完成后才開始執行的。從這種區別可以分析出chrome瀏覽器在對於圖片不采用$(window).load()方法處理時,圖片載入與動態改變圖片的js代碼執行順序不確定。
----------------------------------------------------
上面是文章的全部內容,關於上面的代碼,放到我的頁面中時獲取圖片高度時會報錯,提示沒有提供width方法
var width = $(this).width(); // 圖片實際寬度
var height = $(this).height(); // 圖片實際高度

 

故修改代碼如下:
jQuery(window).load(function () {
  jQuery("div.product_info img").each(function () {
    DrawImage(this, 680, 1000);
  });
});
function DrawImage(ImgD, FitWidth, FitHeight) {   var image = new Image();   image.src = ImgD.src;   if (image.width > 0 && image.height > 0) {     if (image.width / image.height >= FitWidth / FitHeight) {       if (image.width > FitWidth) {         ImgD.width = FitWidth;         ImgD.height = (image.height * FitWidth) / image.width;       } else {         ImgD.width = image.width;         ImgD.height = image.height;       }     } else {       if (image.height > FitHeight) {         ImgD.height = FitHeight;         ImgD.width = (image.width * FitHeight) / image.height;       } else {         ImgD.width = image.width;         ImgD.height = image.height;       }     }   } }

 

 


免責聲明!

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



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