jQuery動(dòng)態(tài)改變圖片顯示大小(修改版)的實(shí)現(xiàn)思路及代碼
當(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)的圖片寬度都相等。
原始代碼:
$(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方法
var width = $(this).width(); // 圖片實(shí)際寬度
var height = $(this).height(); // 圖片實(shí)際高度
故修改代碼如下:
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在頁(yè)面加載時(shí)動(dòng)態(tài)修改圖片尺寸的方法
- jQuery動(dòng)態(tài)修改超鏈接地址的方法
- ASP.NET jQuery 實(shí)例10 動(dòng)態(tài)修改hyperlink的URL值
- jquery實(shí)現(xiàn)實(shí)時(shí)改變網(wǎng)頁(yè)字體大小、字體背景色和顏色的方法
- jQuery實(shí)現(xiàn)自動(dòng)調(diào)整字體大小的方法
- jQuery實(shí)現(xiàn)切換字體大小的方法
- jQuery之字體大小的設(shè)置方法
- jquery更換文章內(nèi)容與改變字體大小代碼
- JQuery 改變頁(yè)面字體大小的實(shí)現(xiàn)代碼(實(shí)時(shí)改變網(wǎng)頁(yè)字體大小)
- jQuery動(dòng)態(tài)修改字體大小的方法【測(cè)試可用】
相關(guān)文章
詳談jQuery unbind 刪除綁定事件 / 移除標(biāo)簽方法
下面小編就為大家?guī)?lái)一篇詳談jQuery unbind 刪除綁定事件 / 移除標(biāo)簽方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03Jquery Ajax.ashx 高效分頁(yè)實(shí)現(xiàn)代碼
Jquery ,大家都熟悉的一個(gè)框架,我對(duì)Jquery正在學(xué)習(xí)中,對(duì)其影響最深的當(dāng)屬 它的選擇器之強(qiáng),ajax與服務(wù)器之間的交談2009-10-10jQuery動(dòng)畫(huà)效果實(shí)現(xiàn)圖片無(wú)縫連續(xù)滾動(dòng)
這篇文章主要為大家介紹了jQuery動(dòng)畫(huà)效果實(shí)現(xiàn)圖片無(wú)縫連續(xù)滾動(dòng),實(shí)現(xiàn)類(lèi)似連續(xù)不間斷的滾動(dòng)廣告位,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-01-01JQuery常用簡(jiǎn)單動(dòng)畫(huà)操作方法回顧與總結(jié)
這篇文章主要介紹了JQuery常用簡(jiǎn)單動(dòng)畫(huà)操作方法,回顧與總結(jié)了jQuery常用的各種動(dòng)畫(huà)效果操作方法及相關(guān)使用技巧,需要的朋友可以參考下2019-12-12jQuery中DOM樹(shù)操作之使用反向插入方法實(shí)例分析
這篇文章主要介紹了jQuery中DOM樹(shù)操作之使用反向插入方法,實(shí)例分析了反向插入方法與插入方法回調(diào)的使用技巧,需要的朋友可以參考下2015-01-01Jquery樹(shù)插件zTree實(shí)現(xiàn)菜單樹(shù)
這篇文章主要為大家詳細(xì)介紹了Jquery樹(shù)插件zTree實(shí)現(xiàn)菜單樹(shù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01