兼容ie、firefox的圖片自動縮放的css跟js代碼分享
更新時間:2013年08月12日 12:34:05 作者:
最近編輯反應,圖片有時候太大了,如果隱藏了,可能部分內容別人就看不到了,如果手工設置圖片大小又太麻煩了,這里就提供一個方法讓也沒的圖片等比例縮放
這個功能主要是解決內容頁中的圖片過大撐出,導致頁面比較難看,就需要這樣的代碼,需要的朋友可以參考下
需求:圖片width<=600px,height<=800。
1、利用max-width,max-height使圖片等比例自動縮放
代碼:
img{max-width: 600px;max-height: 800px;}
由于ie6不支持css max-width,max-height,所以在ie6中需要利用javascript腳本來控制大小。
2、用javascript腳本來兼容ie6,代碼如:
var img_width = img.OffsetWidth;<BR>var img_height = OffsetHeight;
var current_w = (150*img_width)/img_height;
var current_h = (330*img_height)/img_width;
if(img_height>150){
if(img_width>330){
D.css(img,{
width:330 + "px",
height:current_h + "px"
})
}else{
D.css(img,{
width:current_w + "px",
height:150 + "px"
})
}
}else{
if(img_width>330){
D.css(img,{
width:330 + "px",
height:current_h + "px"
})
}else{
D.css(img,{
width:img_width + "px",
height:img_height + "px"
})
}
}
【注1:D.css為KISSY.DOM.css,引用的是kissy類庫中的DOM方法】
【注2:用javascript來控制圖片的尺寸頁面必須要等圖片完全加載出來,所以代碼要包含在window.onload事件中,如果圖片加載速度很慢的話,可能會有一個小缺陷】
所有我們可以結合這兩個一起使用。先用css然后后面再加上js。
需求:圖片width<=600px,height<=800。
1、利用max-width,max-height使圖片等比例自動縮放
代碼:
復制代碼 代碼如下:
img{max-width: 600px;max-height: 800px;}
由于ie6不支持css max-width,max-height,所以在ie6中需要利用javascript腳本來控制大小。
2、用javascript腳本來兼容ie6,代碼如:
復制代碼 代碼如下:
var img_width = img.OffsetWidth;<BR>var img_height = OffsetHeight;
var current_w = (150*img_width)/img_height;
var current_h = (330*img_height)/img_width;
if(img_height>150){
if(img_width>330){
D.css(img,{
width:330 + "px",
height:current_h + "px"
})
}else{
D.css(img,{
width:current_w + "px",
height:150 + "px"
})
}
}else{
if(img_width>330){
D.css(img,{
width:330 + "px",
height:current_h + "px"
})
}else{
D.css(img,{
width:img_width + "px",
height:img_height + "px"
})
}
}
【注1:D.css為KISSY.DOM.css,引用的是kissy類庫中的DOM方法】
【注2:用javascript來控制圖片的尺寸頁面必須要等圖片完全加載出來,所以代碼要包含在window.onload事件中,如果圖片加載速度很慢的話,可能會有一個小缺陷】
所有我們可以結合這兩個一起使用。先用css然后后面再加上js。
相關文章
JavaScript出現(xiàn)setTimeout倒計時誤差的原因分析
setTimeout?倒計時誤差的出現(xiàn)主要與?JavaScript?的事件循環(huán)機制和計時器的執(zhí)行方式有關,本文就來和大家講講具體出現(xiàn)的原因以及解決方法,需要的可以參考一下2023-06-06精解window.setTimeout()&window.setInterval()使用方式與參數(shù)傳遞問題!
精解window.setTimeout()&window.setInterval()使用方式與參數(shù)傳遞問題!...2007-11-11