麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

jQuery動態改變圖片顯示大小(修改版)的實現思路及代碼

2019-11-20 21:23:46
字體:
來源:轉載
供稿:網友

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 91精品国产一区二区三区四区在线 | 91看片在线观看视频 | 黄色毛片视频在线观看 | 久久久入口 | 久久久久久久久成人 | 久久久久女人精品毛片九一 | 欧美成年人在线视频 | 亚洲91精品 | 成年人黄色免费网站 | 欧美成年人在线视频 | 国产精品久久久久久久久久久久久久久久 | 日日草夜夜 | 久久精品久久久久 | 久久精品之 | 亚洲欧美日韩在线 | www.热| 亚洲一级电影在线观看 | 7777在线观看 | 国产乱淫av | 国产成年人视频网站 | 日韩精品网站在线观看 | 国产免费视频一区二区裸体 | 国产精品久久久久国产精品三级 | 91精品国产刺激国语对白 | 久久国产精品久久久久 | 国产一区精品视频 | 香蕉久久久久 | 国产精品99一区二区 | av电影免费在线 | 亚洲精品欧美二区三区中文字幕 | 7777在线视频免费播放 | 成人福利在线播放 | 二区三区四区视频 | 国产大片中文字幕在线观看 | 欧美a在线观看 | 性生活视频网站 | 久久久久久久久久久国产精品 | 国产精品久久久久久久久久电影 | 精品国产一区二区三区在线观看 | 国产va在线观看 | 欧美日韩亚洲一区二区三区 |