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

首頁(yè) > 編程 > JavaScript > 正文

jQuery動(dòng)態(tài)改變圖片顯示大小(修改版)的實(shí)現(xiàn)思路及代碼

2019-11-20 21:23:46
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

當(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)的圖片寬度都相等。

原始代碼:

復(fù)制代碼 代碼如下:

$(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í)行順序不確定。

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

復(fù)制代碼 代碼如下:

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

故修改代碼如下:

復(fù)制代碼 代碼如下:

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

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 石林| 泾源县| 满洲里市| 凤庆县| 博兴县| 黑山县| 宜良县| 仙居县| 兴仁县| 中卫市| 互助| 乌海市| 如东县| 永修县| 平遥县| 长丰县| 育儿| 青神县| 蒙城县| 平乡县| 泰宁县| 海南省| 西华县| 石河子市| 清丰县| 永福县| 香格里拉县| 乌兰浩特市| 渝北区| 施秉县| 邹城市| 晋州市| 托里县| 平和县| 宁南县| 大理市| 鲜城| 和田县| 息烽县| 远安县| 嫩江县|