日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

jQuery动态改变图片显示大小(修改)

發布時間:2024/4/15 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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;}}}}

  原文鏈接:http://blog.csdn.net/roman_yu/article/details/6641911

轉載于:https://www.cnblogs.com/zyzlywq/archive/2012/02/23/2364292.html

總結

以上是生活随笔為你收集整理的jQuery动态改变图片显示大小(修改)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。