web網(wǎng)頁(yè)按比例顯示圖片實(shí)現(xiàn)原理及js代碼
該網(wǎng)站需要上傳高爾夫產(chǎn)品圖片,并以縮略圖顯示在列表上,站點(diǎn)服務(wù)器支持Asp,但不支持aspjpeg之類的生成縮略圖組件,所以將上傳的圖片直接顯示成縮略圖,就需要按比例縮放了,前提是要獲取圖片的長(zhǎng)寬,第一個(gè)想到的方法是在上傳的時(shí)候通過(guò)ADODB.STREAM對(duì)象讀取圖片的長(zhǎng)寬信息保存在數(shù)據(jù)庫(kù)并在頁(yè)面生成的時(shí)候讀取出來(lái)計(jì)算比例。這個(gè)方法明顯的缺點(diǎn)是顯示每張圖片都要在服務(wù)器讀取數(shù)據(jù)并計(jì)算,消耗資源多了也加上了頁(yè)面打開(kāi)時(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è)面在載入圖片過(guò)程中出現(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>
就可以將所有圖片顯示成縮略圖了。
相關(guān)文章
JavaScript標(biāo)準(zhǔn)對(duì)象_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要為大家詳細(xì)介紹了JavaScript標(biāo)準(zhǔn)對(duì)象的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06基于javascript實(shí)現(xiàn)動(dòng)態(tài)時(shí)鐘效果
這篇文章主要為大家詳細(xì)介紹了基于javascript實(shí)現(xiàn)動(dòng)態(tài)時(shí)鐘效果的相關(guān)資料,動(dòng)態(tài)顯示系統(tǒng)當(dāng)前時(shí)間,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-02-02javascript定時(shí)保存表單數(shù)據(jù)的代碼
我相信有不少TX用過(guò)QQ或163的郵箱吧?他們中有一個(gè)比較有用且有趣的功能,如果您在編寫郵件,那在固定一個(gè)時(shí)間頻率內(nèi),它會(huì)自動(dòng)將您的郵件內(nèi)容保存起來(lái),以免丟失。2011-03-03關(guān)于layui flow loading占位圖的實(shí)現(xiàn)方法
今天小編就為大家分享一篇關(guān)于layui flow loading占位圖的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09Javascript立即執(zhí)行函數(shù)(IIFE)實(shí)例詳解
IIFE全拼Imdiately?Invoked?Function?Expression,是一個(gè)在定義的時(shí)候就立即執(zhí)行的JavaScript函數(shù),這篇文章主要給大家介紹了關(guān)于Javascript立即執(zhí)行函數(shù)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04一個(gè)網(wǎng)頁(yè)標(biāo)題title的閃動(dòng)提示效果實(shí)現(xiàn)思路
通過(guò)網(wǎng)頁(yè)title來(lái)提示用戶有新消息這個(gè)功能很常見(jiàn),下面有個(gè)不錯(cuò)的示例,大家可以參考下2014-03-03微信小程序?qū)崿F(xiàn)電子簽名并導(dǎo)出圖片
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)電子簽名,并導(dǎo)出圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-05-05