国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網站 > WEB開發 > 正文

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

2024-04-27 15:01:18
字體:
來源:轉載
供稿:網友

代碼如下:

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

  

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

修改方法如下:

$(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動態改變圖片顯示大小的方法,希望大家喜歡,更希望朋友請持續關注本站,謝謝。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 沧州市| 镇沅| 正宁县| 营口市| 德阳市| 崇礼县| 武山县| 泽普县| 玉林市| 大姚县| 山西省| 衡水市| 和硕县| 松阳县| 宜丰县| 大连市| 寻甸| 鄂州市| 大新县| 仲巴县| 皮山县| 视频| 永顺县| 璧山县| 象山县| 龙陵县| 潼关县| 黄冈市| 陵川县| 宝鸡市| 绍兴县| 元氏县| 孝昌县| 阿克苏市| 伊宁县| 和平区| 开鲁县| 繁昌县| 缙云县| 苏尼特右旗| 台东市|