亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

如何解決谷歌瀏覽器下jquery無(wú)法獲取圖片的尺寸

 更新時(shí)間:2015年09月10日 10:56:33   作者:Ajaxc  
本章節(jié)介紹一下在谷歌瀏覽器下利用jquery無(wú)法獲取圖片尺寸的現(xiàn)象,而在IE和火狐瀏覽器下能夠正常獲得,當(dāng)然也不是任何時(shí)候都無(wú)法獲取圖片尺寸,下面給大家介紹遇到此問(wèn)題該如何解決

代碼如下:

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

以上代碼在IE和火狐中沒(méi)有問(wèn)題,但是在谷歌中可能會(huì)出現(xiàn)問(wèn)題,之所以沒(méi)貨的尺寸就是因?yàn)閳D片沒(méi)有加載完成。

修改方法如下:

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

還有點(diǎn)時(shí)間,接下來(lái)在給大家分享jQuery動(dòng)態(tài)改變圖片顯示大小的方法,具體內(nèi)容如下。

當(dāng)我們要顯示后臺(tái)傳過(guò)來(lái)若干個(gè)尺寸不一的圖片時(shí),為了保證圖片大小的一致性及比例的協(xié)調(diào),需要?jiǎng)討B(tài)改變圖片顯示尺寸。通過(guò)搜索,我們可以從網(wǎng)上找到實(shí)現(xiàn)此功能的jQuery代碼如下。這段代碼可以使圖片的大小保持在一定范圍內(nèi),如果圖片的原始尺寸都大于max*值,則顯示出來(lái)的圖片寬度都相等。

原始代碼:

$(document).ready(function() {
   $('.post img').each(function() {
   var maxWidth = 100; // 圖片最大寬度
   var maxHeight = 100;  // 圖片最大高度
   var ratio = 0; // 縮放比例
   var width = $(this).width();  // 圖片實(shí)際寬度
   var height = $(this).height(); // 圖片實(shí)際高度
   // 檢查圖片是否超寬
   if(width > maxWidth){
     ratio = maxWidth / width;  // 計(jì)算縮放比例
     $(this).css("width", maxWidth); // 設(shè)定實(shí)際顯示寬度
     height = height * ratio;  // 計(jì)算等比例縮放后的高度 
     $(this).css("height", height); // 設(shè)定等比例縮放后的高度
   }
   // 檢查圖片是否超高
   if(height > maxHeight){
     ratio = maxHeight / height; // 計(jì)算縮放比例
     $(this).css("height", maxHeight);  // 設(shè)定實(shí)際顯示高度
     width = width * ratio;  // 計(jì)算等比例縮放后的高度
     $(this).css("width", width * ratio);  // 設(shè)定等比例縮放后的高度
   }
 });
 });

  在我的js代碼中,也采取了這種寫(xiě)法。然而在不同的瀏覽器測(cè)試效果時(shí),發(fā)現(xiàn)此種寫(xiě)法不能適應(yīng)chrome瀏覽器(chrome版本號(hào)為10.0.648.204),會(huì)產(chǎn)生圖片以原有尺寸顯示出來(lái)的bug。后來(lái)把$('.post img').each()的代碼用$(window).load()方法包裝起來(lái),就解決了chrome瀏覽器顯示不正確的問(wèn)題。那么在chrome瀏覽器中為什么會(huì)產(chǎn)生bug,并且$(document).ready和$(window).load有什么區(qū)別呢?

原來(lái)document ready事件是在HTML文檔載入即DOM準(zhǔn)備好就開(kāi)始執(zhí)行了,即使圖片資源還沒(méi)有加載進(jìn)來(lái)。而window load事件執(zhí)行的稍晚一些,它是在整個(gè)頁(yè)面包括frames, objects和images都加載完成后才開(kāi)始執(zhí)行的。從這種區(qū)別可以分析出chrome瀏覽器在對(duì)于圖片不采用$(window).load()方法處理時(shí),圖片載入與動(dòng)態(tài)改變圖片的js代碼執(zhí)行順序不確定。

----------------------------------------------------

上面是文章的全部類(lèi)容,關(guān)于上面的代碼,放到我的頁(yè)面中時(shí)獲取圖片高度時(shí)會(huì)報(bào)錯(cuò),提示沒(méi)有提供width方法

var width = $(this).width();  // 圖片實(shí)際寬度
var height = $(this).height(); // 圖片實(shí)際高度

故修改代碼如下:

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;
          }
        }
      }
    }

以上內(nèi)容是本人給大家分享的如何解決谷歌瀏覽器下jquery無(wú)法獲取圖片的尺寸以及jQuery動(dòng)態(tài)改變圖片顯示大小的方法,希望大家喜歡,更希望朋友請(qǐng)持續(xù)關(guān)注本站,謝謝。

相關(guān)文章

最新評(píng)論