jQuery實(shí)現(xiàn)等比例縮放大圖片讓大圖片自適應(yīng)頁(yè)面布局
更新時(shí)間:2013年10月16日 16:03:02 作者:
遇到大圖片將頁(yè)面容器“撐破”的情況在進(jìn)行頁(yè)面布局時(shí)會(huì)經(jīng)常遇到吧,在本文將為大家講述使用jQuery實(shí)現(xiàn)按比例縮放大圖片,讓大圖片自適應(yīng)頁(yè)面布局
在布局頁(yè)面時(shí),有時(shí)會(huì)遇到大圖片將頁(yè)面容器“撐破”的情況,尤其是加載外鏈圖片(通常是通過(guò)采集的外站的圖片)。那么本文將為您講述使用jQuery如何按比例縮放大圖片,讓大圖片自適應(yīng)頁(yè)面布局。
通常我們處理縮略圖是使用后臺(tái)代碼(PHP、.net、Java等)根據(jù)大圖片生成一定尺寸的縮略圖,來(lái)供前臺(tái)頁(yè)面調(diào)用,當(dāng)然也有使用前臺(tái)javascript腳本將加載后的大圖強(qiáng)行縮放,變成所謂的縮略圖,這種方法不可取。但是,針對(duì)網(wǎng)站內(nèi)容頁(yè),如本站文章詳情頁(yè),如果需要加載一張很大的圖片時(shí),為了防止“撐破”布局,我們使用jQuery來(lái)等比例縮放圖片。我們分兩種情況來(lái)講述:
1.已知圖片尺寸
<div id="demo1">
<img src="a.jpg" width="800" height="300" alt="圖片">
</div>
當(dāng)頁(yè)面加載的圖片中含有屬性width和height值,則可以使用幾句簡(jiǎn)單的jQuery代碼實(shí)現(xiàn)等比例縮放。
$(function(){
var w = $("#demo1").width();//容器寬度
$("#demo1 img").each(function(){//如果有很多圖片,我們可以使用each()遍歷
var img_w = $(this).width();//圖片寬度
var img_h = $(this).height();//圖片高度
if(img_w>w){//如果圖片寬度超出容器寬度--要撐破了
var height = (w*img_h)/img_w; //高度等比縮放
$(this).css({"width":w,"height":height});//設(shè)置縮放后的寬度和高度
}
});
});
2.未知圖片尺寸
當(dāng)頁(yè)面加載的圖片尺寸未知的情況下,上述代碼則不能進(jìn)行有效的縮放,這種情況多出現(xiàn)在采集的外部鏈接圖片。
<div id="demo2">
<img src="a.jpg" alt="圖片">
</div>
所幸的是,有好心朋友已經(jīng)寫(xiě)出來(lái)專(zhuān)門(mén)的插件來(lái)處理,而且跨瀏覽器,解決了前端朋友們的一大難題。
下面隆重介紹下autoIMG。
autoIMG可以快速對(duì)文章圖片進(jìn)行尺寸自適應(yīng),它利用瀏覽器獲取圖片文件頭尺寸數(shù)據(jù),無(wú)需等待圖片加載完成。
autoIMG兼容:Chrome | Firefox | Sifari | Opera | IE6 | IE7 | IE8 | ...
調(diào)用autoIMG插件方法相當(dāng)簡(jiǎn)單:
$(function(){
$("#demo2").autoIMG();
});
autoIMG實(shí)例下載
通常我們處理縮略圖是使用后臺(tái)代碼(PHP、.net、Java等)根據(jù)大圖片生成一定尺寸的縮略圖,來(lái)供前臺(tái)頁(yè)面調(diào)用,當(dāng)然也有使用前臺(tái)javascript腳本將加載后的大圖強(qiáng)行縮放,變成所謂的縮略圖,這種方法不可取。但是,針對(duì)網(wǎng)站內(nèi)容頁(yè),如本站文章詳情頁(yè),如果需要加載一張很大的圖片時(shí),為了防止“撐破”布局,我們使用jQuery來(lái)等比例縮放圖片。我們分兩種情況來(lái)講述:
1.已知圖片尺寸
復(fù)制代碼 代碼如下:
<div id="demo1">
<img src="a.jpg" width="800" height="300" alt="圖片">
</div>
當(dāng)頁(yè)面加載的圖片中含有屬性width和height值,則可以使用幾句簡(jiǎn)單的jQuery代碼實(shí)現(xiàn)等比例縮放。
復(fù)制代碼 代碼如下:
$(function(){
var w = $("#demo1").width();//容器寬度
$("#demo1 img").each(function(){//如果有很多圖片,我們可以使用each()遍歷
var img_w = $(this).width();//圖片寬度
var img_h = $(this).height();//圖片高度
if(img_w>w){//如果圖片寬度超出容器寬度--要撐破了
var height = (w*img_h)/img_w; //高度等比縮放
$(this).css({"width":w,"height":height});//設(shè)置縮放后的寬度和高度
}
});
});
2.未知圖片尺寸
當(dāng)頁(yè)面加載的圖片尺寸未知的情況下,上述代碼則不能進(jìn)行有效的縮放,這種情況多出現(xiàn)在采集的外部鏈接圖片。
復(fù)制代碼 代碼如下:
<div id="demo2">
<img src="a.jpg" alt="圖片">
</div>
所幸的是,有好心朋友已經(jīng)寫(xiě)出來(lái)專(zhuān)門(mén)的插件來(lái)處理,而且跨瀏覽器,解決了前端朋友們的一大難題。
下面隆重介紹下autoIMG。
autoIMG可以快速對(duì)文章圖片進(jìn)行尺寸自適應(yīng),它利用瀏覽器獲取圖片文件頭尺寸數(shù)據(jù),無(wú)需等待圖片加載完成。
autoIMG兼容:Chrome | Firefox | Sifari | Opera | IE6 | IE7 | IE8 | ...
調(diào)用autoIMG插件方法相當(dāng)簡(jiǎn)單:
復(fù)制代碼 代碼如下:
$(function(){
$("#demo2").autoIMG();
});
autoIMG實(shí)例下載
您可能感興趣的文章:
- 基于jquery的防止大圖片撐破頁(yè)面的實(shí)現(xiàn)代碼(立即縮放)
- jQuery+css實(shí)現(xiàn)的點(diǎn)擊圖片放大縮小預(yù)覽功能示例【圖片預(yù)覽 查看大圖】
- jQuery實(shí)現(xiàn)鼠標(biāo)滑過(guò)商品小圖片上顯示對(duì)應(yīng)大圖片功能【測(cè)試可用】
- jQuery實(shí)現(xiàn)鼠標(biāo)滑過(guò)預(yù)覽圖片大圖效果的方法
- jQuery實(shí)現(xiàn)大圖輪播
- jQuery實(shí)現(xiàn)的小圖列表,大圖展示效果幻燈片示例
- jquery插件jquery.LightBox.js實(shí)現(xiàn)點(diǎn)擊放大圖片并左右點(diǎn)擊切換效果(附demo源碼下載)
- jQuery實(shí)現(xiàn)點(diǎn)擊小圖片淡入淡出顯示大圖片特效
- jQuery實(shí)現(xiàn)點(diǎn)擊查看大圖并以彈框的形式居中
- 基于jQuery插件實(shí)現(xiàn)點(diǎn)擊小圖顯示大圖效果
- jquery實(shí)現(xiàn)移動(dòng)端點(diǎn)擊圖片查看大圖特效
- jQuery實(shí)現(xiàn)點(diǎn)擊小圖顯示大圖代碼分享
- jquery 圖片點(diǎn)擊放大預(yù)覽功能詳解
相關(guān)文章
jquery form表單提交插件asp.net后臺(tái)中文解碼
對(duì)于jquery form表單提交插件jquery.form.js,在提交表單數(shù)據(jù)時(shí),如果表單數(shù)據(jù)有中文,則被提交的數(shù)據(jù)是要經(jīng)過(guò)編碼的。2010-06-06使用jQuery時(shí)Form表單元素ID和name命名大忌
將自己的表單元素ID和name命名為了nodeName,在chrome瀏覽器下報(bào)錯(cuò),結(jié)果發(fā)現(xiàn)是表單元素命名的原因2014-03-03jquery 操作單選框,復(fù)選框,下拉列表實(shí)現(xiàn)代碼
jquery 操作單選框,復(fù)選框,下拉列表實(shí)現(xiàn)代碼,需要的朋友可以參考下。2009-10-10jQuery列表動(dòng)態(tài)增加和刪除的實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于jQuery列表動(dòng)態(tài)增加和刪除的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11