首頁 >web前端 >js教程 >如何解決Google瀏覽器下jquery無法取得圖片的尺寸_jquery

如何解決Google瀏覽器下jquery無法取得圖片的尺寸_jquery

WBOY
WBOY原創
2016-05-16 15:39:511217瀏覽

程式碼如下:

$(document).ready(function(){ 
 var img_h=$img.height();  
 var img_w=$img.width();  
}) 

以上程式碼在IE和火狐中沒有問題,但是在Google中可能會出現問題,之所以沒貨的尺寸就是因為圖片沒有載入完成。

修改方法如下:

$(document).ready(function(){ 
 $img.load(function(){  
  var img_h=$img.height();  
  var img_w=$img.width();  
 }) 
}) 

還有一點時間,接下來在跟大家分享jQuery動態改變圖片顯示大小的方法,具體內容如下。

當我們要顯示後台傳過來若干個尺寸不一的圖片時,為了確保圖片大小的一致性及比例的協調,需要動態改變圖片顯示尺寸。透過搜索,我們可以從網路上找到實現此功能的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;
          }
        }
      }
    }

以上內容是本人給大家分享的如何解決谷歌瀏覽器下jquery無法獲取圖片的尺寸以及jQuery動態改變圖片顯示大小的方法,希望大家喜歡,更希望朋友請持續關注本站,謝謝。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn