91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

jQuery如何動態改變圖片顯示大小

發布時間:2021-10-19 13:52:16 來源:億速云 閱讀:171 作者:小新 欄目:web開發

小編給大家分享一下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有什么區別呢?

unity3d下載http://www.unitymanual.com/


原來document ready事件是在HTML文檔載入即DOM準備好就開始執行了,即使圖片資源還沒有加載進來。而window load事件執行的稍晚一些,它是在整個頁面包括frames, objects和p_w_picpaths都加載完成后才開始執行的。從這種區別可以分析出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 p_w_picpath = new Image();
           p_w_picpath.src = ImgD.src;
           if (p_w_picpath.width > 0 && p_w_picpath.height > 0) {
               if (p_w_picpath.width / p_w_picpath.height >= FitWidth / FitHeight) {
                   if (p_w_picpath.width > FitWidth) {
                       ImgD.width = FitWidth;
                       ImgD.height = (p_w_picpath.height * FitWidth) / p_w_picpath.width;
                   } else {
                       ImgD.width = p_w_picpath.width;
                       ImgD.height = p_w_picpath.height;
                   }
               } else {
                   if (p_w_picpath.height > FitHeight) {
                       ImgD.height = FitHeight;
                       ImgD.width = (p_w_picpath.width * FitHeight) / p_w_picpath.height;
                   } else {
                       ImgD.width = p_w_picpath.width;
                       ImgD.height = p_w_picpath.height;
                   }
               }
           }
       }

以上是“jQuery如何動態改變圖片顯示大小”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

冷水江市| 西平县| 南岸区| 溆浦县| 秭归县| 仙游县| 通辽市| 栾川县| 固阳县| 阜新| 鹿泉市| 曲松县| 洱源县| 涡阳县| 浮山县| 获嘉县| 丹寨县| 双城市| 双牌县| 内江市| 达孜县| 惠水县| 蒲城县| 嘉义市| 洛浦县| 民乐县| 资中县| 信阳市| 奉贤区| 阜新| 吴川市| 苍山县| 临江市| 灵石县| 会泽县| 虞城县| 营口市| 扎囊县| 太和县| 静海县| 肇东市|