web網(wǎng)頁(yè)按比例顯示圖片實(shí)現(xiàn)原理及js代碼
更新時(shí)間:2013年08月09日 10:52:21 作者:
由于上傳圖片的大小是未知的,在顯示成縮略圖的時(shí)候必須進(jìn)行按比例的縮放才能美觀地顯示,本文將為大家簡(jiǎn)單的介紹一種比較不錯(cuò)的方法,有此需求的朋友可以參考下
在動(dòng)態(tài)站點(diǎn)上經(jīng)常需要上傳自己的圖片,而這些圖片的大小是未知的,在顯示成縮略圖的時(shí)候必須進(jìn)行按比例的縮放才能美觀地顯示。以最近做的golf網(wǎng)站(http://www.changligolfsales.com)做例子。
該網(wǎng)站需要上傳高爾夫產(chǎn)品圖片,并以縮略圖顯示在列表上,站點(diǎn)服務(wù)器支持Asp,但不支持aspjpeg之類的生成縮略圖組件,所以將上傳的圖片直接顯示成縮略圖,就需要按比例縮放了,前提是要獲取圖片的長(zhǎng)寬,第一個(gè)想到的方法是在上傳的時(shí)候通過ADODB.STREAM對(duì)象讀取圖片的長(zhǎng)寬信息保存在數(shù)據(jù)庫(kù)并在頁(yè)面生成的時(shí)候讀取出來計(jì)算比例。這個(gè)方法明顯的缺點(diǎn)是顯示每張圖片都要在服務(wù)器讀取數(shù)據(jù)并計(jì)算,消耗資源多了也加上了頁(yè)面打開時(shí)延。
而第二個(gè)方法使用Javascript是將計(jì)算量轉(zhuǎn)移到了客戶端。
原理是在頁(yè)面載入完成后(onload觸發(fā))在客戶端使用Javascript讀取每張圖片的大小并進(jìn)行縮放。
//將imageDest圖片的大小按比例縮放,適合顯示在寬W和高H的區(qū)域內(nèi)
function ResizeImage(imageDest, W, H)
{
//顯示框?qū)挾萕,高度H
var image = new Image();
image.src = imageDest.src;
if(image.width>0 && image.height>0)
{
//比較縱橫比
if(image.width/image.height >= W/H)//相對(duì)顯示框:寬>高
{
if(image.width > W) //寬度大于顯示框?qū)挾萕,應(yīng)壓縮高度
{
imageDest.width = W;
imageDest.height = (image.height*W)/image.width;
}
else //寬度少于或等于顯示框?qū)挾萕,圖片完全顯示
{
imageDest.width = image.width;
imageDest.height = image.height;
}
}
else//同理
{
if(image.height > H)
{
imageDest.height = H;
imageDest.width = (image.width*H)/image.height;
}
else
{
imageDest.width = image.width;
imageDest.height = image.height;
}
}
}
}
以上函數(shù)對(duì)圖片進(jìn)行縮放。
golf網(wǎng)站的每張縮略圖的id都設(shè)為imgProductItem,如:<img src="<%= imgPath %>" name="imgProductItem" width="150" height="113" border="0" id="imgProductItem" />,里面的150x113就是顯示框的最大尺寸,因?yàn)樘幚砗瘮?shù)必須在onload完成時(shí)運(yùn)行,所以這里必須設(shè)置一定的大小,要不整個(gè)頁(yè)面在載入圖片過程中出現(xiàn)排版錯(cuò)亂,到運(yùn)行了RsizeAllImageById才恢復(fù)正常。
添加一個(gè)批量操作的函數(shù):
//將頁(yè)面內(nèi)所有指定id的圖片按比例縮放
function RsizeAllImageById(id, W, H)
{
var imgs = document.getElementsByTagName("img");
for(var i=0; i<imgs.length; i++)
{
if(imgs[i].id == id)
{
ResizeImage(imgs[i], W, H);
}
}
}
這樣在頁(yè)面的body添加
<body onload="javascript:init();">;在head區(qū)添加:
<mce:script language="javascript"><!--
function init()
{
RsizeAllImageById("imgProductItem", 150, 113);
}
// --></mce:script>
就可以將所有圖片顯示成縮略圖了。
該網(wǎng)站需要上傳高爾夫產(chǎn)品圖片,并以縮略圖顯示在列表上,站點(diǎn)服務(wù)器支持Asp,但不支持aspjpeg之類的生成縮略圖組件,所以將上傳的圖片直接顯示成縮略圖,就需要按比例縮放了,前提是要獲取圖片的長(zhǎng)寬,第一個(gè)想到的方法是在上傳的時(shí)候通過ADODB.STREAM對(duì)象讀取圖片的長(zhǎng)寬信息保存在數(shù)據(jù)庫(kù)并在頁(yè)面生成的時(shí)候讀取出來計(jì)算比例。這個(gè)方法明顯的缺點(diǎn)是顯示每張圖片都要在服務(wù)器讀取數(shù)據(jù)并計(jì)算,消耗資源多了也加上了頁(yè)面打開時(shí)延。
而第二個(gè)方法使用Javascript是將計(jì)算量轉(zhuǎn)移到了客戶端。
原理是在頁(yè)面載入完成后(onload觸發(fā))在客戶端使用Javascript讀取每張圖片的大小并進(jìn)行縮放。
復(fù)制代碼 代碼如下:
//將imageDest圖片的大小按比例縮放,適合顯示在寬W和高H的區(qū)域內(nèi)
function ResizeImage(imageDest, W, H)
{
//顯示框?qū)挾萕,高度H
var image = new Image();
image.src = imageDest.src;
if(image.width>0 && image.height>0)
{
//比較縱橫比
if(image.width/image.height >= W/H)//相對(duì)顯示框:寬>高
{
if(image.width > W) //寬度大于顯示框?qū)挾萕,應(yīng)壓縮高度
{
imageDest.width = W;
imageDest.height = (image.height*W)/image.width;
}
else //寬度少于或等于顯示框?qū)挾萕,圖片完全顯示
{
imageDest.width = image.width;
imageDest.height = image.height;
}
}
else//同理
{
if(image.height > H)
{
imageDest.height = H;
imageDest.width = (image.width*H)/image.height;
}
else
{
imageDest.width = image.width;
imageDest.height = image.height;
}
}
}
}
以上函數(shù)對(duì)圖片進(jìn)行縮放。
golf網(wǎng)站的每張縮略圖的id都設(shè)為imgProductItem,如:<img src="<%= imgPath %>" name="imgProductItem" width="150" height="113" border="0" id="imgProductItem" />,里面的150x113就是顯示框的最大尺寸,因?yàn)樘幚砗瘮?shù)必須在onload完成時(shí)運(yùn)行,所以這里必須設(shè)置一定的大小,要不整個(gè)頁(yè)面在載入圖片過程中出現(xiàn)排版錯(cuò)亂,到運(yùn)行了RsizeAllImageById才恢復(fù)正常。
添加一個(gè)批量操作的函數(shù):
復(fù)制代碼 代碼如下:
//將頁(yè)面內(nèi)所有指定id的圖片按比例縮放
function RsizeAllImageById(id, W, H)
{
var imgs = document.getElementsByTagName("img");
for(var i=0; i<imgs.length; i++)
{
if(imgs[i].id == id)
{
ResizeImage(imgs[i], W, H);
}
}
}
這樣在頁(yè)面的body添加
復(fù)制代碼 代碼如下:
<body onload="javascript:init();">;在head區(qū)添加:
<mce:script language="javascript"><!--
function init()
{
RsizeAllImageById("imgProductItem", 150, 113);
}
// --></mce:script>
就可以將所有圖片顯示成縮略圖了。
相關(guān)文章
詳解JavaScript實(shí)現(xiàn)繼承的五種經(jīng)典方式(附圖解)
JavaScript中的繼承是一種機(jī)制,通過它可以創(chuàng)建一個(gè)對(duì)象,該對(duì)象可以享有另一個(gè)對(duì)象的屬性和方法,本文將詳細(xì)的為大家介紹實(shí)現(xiàn)繼承的五種經(jīng)典方式,感興趣的小伙伴跟著小編一起來看看吧2023-08-08
js實(shí)現(xiàn)用戶注冊(cè)協(xié)議倒計(jì)時(shí)的方法
這篇文章主要介紹了js實(shí)現(xiàn)用戶注冊(cè)協(xié)議倒計(jì)時(shí)的方法,是開發(fā)會(huì)員注冊(cè)功能時(shí)非常實(shí)用的技巧,需要的朋友可以參考下2015-01-01
javascript斷點(diǎn)調(diào)試心得分享
javascript中程序是怎么可以中斷執(zhí)行,然后一步一步走下去。而且debug的時(shí)候,可以看到變量,調(diào)用棧等東西。這個(gè)是如何實(shí)現(xiàn)的?2016-04-04
js獲取select默認(rèn)選中的Option并不是當(dāng)前選中值
這篇文章主要介紹了js如何獲取select默認(rèn)選中的Option并不是當(dāng)前選中的值,需要的朋友可以參考下2014-05-05
JavaScript必看的10道面試題總結(jié)(推薦)
JavaScript 已經(jīng)成為全棧開發(fā)技能的基石,在全棧開發(fā)面試中都會(huì)不可避免地涉及到與 JavaScript 有關(guān)的問題。這篇文章主要給大家介紹了關(guān)于JavaScript必看的10道面試題,需要的朋友可以參考下2021-05-05
js+css實(shí)現(xiàn)的圓角邊框TAB選項(xiàng)卡滑動(dòng)門代碼分享(2款)
這篇文章主要為大家詳細(xì)介紹了兩種js+css實(shí)現(xiàn)的圓角邊框TAB選項(xiàng)卡滑動(dòng)門效果,很實(shí)用的代碼,推薦給大家,有需要的小伙伴可以參考下2015-08-08
新發(fā)現(xiàn)原來documenet.URL也可以實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn)
新發(fā)現(xiàn)原來documenet.URL也可以實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn)...2007-08-08

