jQuery實現等比例縮放大圖片讓大圖片自適應頁面配置

來源:互聯網
上載者:User

在布局頁面時,有時會遇到大圖片將頁面容器“撐破”的情況,尤其是載入外鏈圖片(通常是通過採集的外站的圖片)。那麼本文將為您講述使用jQuery如何按比例縮放大圖片,讓大圖片自適應頁面配置。

通常我們處理縮圖是使用後台代碼(PHP、.net、Java等)根據大圖片產生一定尺寸的縮圖,來供前台頁面調用,當然也有使用前台javascript指令碼將載入後的大圖強行縮放,變成所謂的縮圖,這種方法不可取。但是,針對網站內容頁,如本站文章詳情頁,如果需要載入一張很大的圖片時,為了防止“撐破”布局,我們使用jQuery來等比例縮放圖片。我們分兩種情況來講述:

1.已知圖片尺寸
複製代碼 代碼如下:
<div id="demo1">
<img src="a.jpg" width="800" height="300" alt="圖片">
</div>

當頁面載入的圖片中含有屬性width和height值,則可以使用幾句簡單的jQuery代碼實現等比例縮放。
複製代碼 代碼如下:
$(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});//設定縮放後的寬度和高度
}
});
});

2.未知圖片尺寸

當頁面載入的圖片尺寸未知的情況下,上述代碼則不能進行有效縮放,這種情況多出現在採集的外部連結圖片。
複製代碼 代碼如下:
<div id="demo2">
<img src="a.jpg" alt="圖片">
</div>

所幸的是,有好心朋友已經寫出來專門的外掛程式來處理,而且跨瀏覽器,解決了前端朋友們的一大難題。

下面隆重介紹下autoIMG。

autoIMG可以快速對文章圖片進行尺寸自適應,它利用瀏覽器擷取圖片檔案頭尺寸資料,無需等待圖片載入完成。

autoIMG相容:Chrome | Firefox | Sifari | Opera | IE6 | IE7 | IE8 | ...

調用autoIMG外掛程式方法相當簡單:
複製代碼 代碼如下:
$(function(){
$("#demo2").autoIMG();
});

autoIMG執行個體下載

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.