如何解決谷歌瀏覽器下jquery無(wú)法獲取圖片的尺寸
代碼如下:
$(document).ready(function(){ var img_h=$img.height(); var img_w=$img.width(); })
以上代碼在IE和火狐中沒(méi)有問(wèn)題,但是在谷歌中可能會(huì)出現(xiàn)問(wèn)題,之所以沒(méi)貨的尺寸就是因?yàn)閳D片沒(méi)有加載完成。
修改方法如下:
$(document).ready(function(){ $img.load(function(){ var img_h=$img.height(); var img_w=$img.width(); }) })
還有點(diǎn)時(shí)間,接下來(lái)在給大家分享jQuery動(dòng)態(tài)改變圖片顯示大小的方法,具體內(nèi)容如下。
當(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í)行順序不確定。
----------------------------------------------------
上面是文章的全部類(lèi)容,關(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; } } } }
以上內(nèi)容是本人給大家分享的如何解決谷歌瀏覽器下jquery無(wú)法獲取圖片的尺寸以及jQuery動(dòng)態(tài)改變圖片顯示大小的方法,希望大家喜歡,更希望朋友請(qǐng)持續(xù)關(guān)注本站,謝謝。
相關(guān)文章
jQuery插件之Tocify動(dòng)態(tài)節(jié)點(diǎn)目錄菜單生成器附源碼下載
Tocify是一個(gè)能夠動(dòng)態(tài)生成文章節(jié)點(diǎn)目錄的jQuery插件,通過(guò)本文給大家分享jQuery插件之Tocify動(dòng)態(tài)節(jié)點(diǎn)目錄菜單生成器,對(duì)tocify菜單生成器相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2016-01-01jQuery實(shí)現(xiàn)鼠標(biāo)滑過(guò)商品小圖片上顯示對(duì)應(yīng)大圖片功能【測(cè)試可用】
這篇文章主要介紹了jQuery實(shí)現(xiàn)鼠標(biāo)滑過(guò)商品小圖片上顯示對(duì)應(yīng)大圖片功能,涉及jQuery事件響應(yīng)、元素遍歷及屬性動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-04-04JQuery學(xué)習(xí)筆記 實(shí)現(xiàn)圖片翻轉(zhuǎn)效果和TAB標(biāo)簽切換效果
為了保證前臺(tái)頁(yè)面的整潔,我們習(xí)慣性地將CSS放入一個(gè)單獨(dú)的.CSS文件中以便調(diào)用,而JS也同樣可以放到單獨(dú)的JS文件中去,并且頁(yè)面上的事件如onclick,onmouseover也可以分離出來(lái),現(xiàn)在網(wǎng)上比較流行JQuery2008-11-11jquery自定義插件——window的實(shí)現(xiàn)【示例代碼】
下面小編就為大家?guī)?lái)一篇jquery自定義插件——window的實(shí)現(xiàn)【示例代碼】。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考2016-05-05javascript異步處理與Jquery deferred對(duì)象用法總結(jié)
這篇文章主要介紹了javascript異步處理與Jquery deferred對(duì)象用法,結(jié)合實(shí)例形式總結(jié)分析了jQuery異步請(qǐng)求處理相關(guān)操作技巧,需要的朋友可以參考下2019-06-06jquery實(shí)現(xiàn)轉(zhuǎn)盤(pán)抽獎(jiǎng)功能
本文主要介紹了用的jqueryRotate插件實(shí)現(xiàn)轉(zhuǎn)盤(pán)抽獎(jiǎng)功能的方法,具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-01-01jQuery leonaScroll 1.1 自定義滾動(dòng)條插件(推薦)
這篇文章主要介紹了jQuery leonaScroll 1.1 自定義滾動(dòng)條插件(推薦)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09