JS - 設(shè)置圖片等比縮放

直接上代碼:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title></title>
        <style>
            .box{
                width: 300px;
                height: 400px;
                margin: 50px 50px;
                position: relative;
                /* overflow: hidden; */
            }
            .show{
                width: 100%;
                height: 100%;
                background-color: rgba(0,0,0,0.4);
                border: 1px solid red;
                position: absolute;
                left: 0;
                top: 0;
                z-index: 999;
                color: #FFF;
                text-align: center;
                line-height: 400px;
                font-size: 24px;
                font-weight: bold;
            }
        </style>
    </head>
    <body>
        
        <div class="box">
            <div class="show">顯示區(qū)域</div>
            <img class="img" src="img/5.png" />
        </div>
        
        <div class="box" style="overflow: hidden;">
            <img class="img" src="img/5.png" />
        </div>
         
    <script>
        
        var box = document.getElementsByClassName("box")[0]; // box
        var img = document.getElementsByClassName("img")[0]; // img
        var img1 = document.getElementsByClassName("img")[1]; // img
        // 計(jì)算后的圖寬,高, 定位:左是己,上
        var count_width, 
            count_height, 
            cont_left = 0, 
            cont_top = 0; 
        
        // 獲取圖片地址汛兜,圖片的數(shù)據(jù)都沒有被加載前它的寬高默認(rèn)就是0颠焦, 需要用onload事件獲取圖片數(shù)據(jù)
        img.onload = function(){
            
            // 獲取圖片寬高
            let img_width = img.width,
                img_height = img.height;
            let img_ratio = img_width / img_height; // 計(jì)算圖片寬高比
            console.log("圖w:"+img_width, "圖h:"+img_height, "圖寬高比:"+img_ratio);
            
            // 獲取盒子寬高
            let box_width = box.clientWidth,
                box_height = box.clientHeight;
            let box_ratio = box_width / box_height; // 計(jì)算盒子寬高比
            console.log("盒w:"+box_width, "盒h:"+box_height, "盒寬高比:"+box_ratio);
            
            // 圖片比例大于盒子比例, 等比縮放左右居中
            if( img_ratio > box_ratio ) {
                count_height = box_height;                        // 計(jì)算圖h = 盒h
                count_width = box_height * img_ratio;            // 計(jì)算圖w = 盒h * 圖寬高比
                cont_left = -((count_width/2)-(box_width/2));   // 計(jì)算圖居中定位 =  -((計(jì)算后圖w/2)-(盒w/2))
                
            //     圖片比例小于盒子比例
            }else if ( img_ratio < box_ratio ) {
                
                // 判斷圖寬小于盒寬就等比縮放上下居中,否則等比縮放左右居中
                if( img_width < box_width ){
                    // 上下居中
                    count_height = img_height * box_width / img_width; // 計(jì)算圖h = 圖h * 盒w / 圖w
                    count_width = box_width;                           // 計(jì)算圖w = 盒w
                    cont_top = -((count_height/2)-(box_height/2));    // 計(jì)算圖居中定位 = -((計(jì)算后圖w/2)-(盒w/2))
                }else{
                    // 左右居中
                    count_height = box_height;                      // 計(jì)算圖h = 盒h
                    count_width = box_height * img_ratio;          // 計(jì)算圖w = 盒h * 圖寬高比
                    cont_left = (box_width/2) - (count_width/2)   // 計(jì)算圖居中定位 = (計(jì)算后圖w/2)-(盒w/2)
                }
            }
            
            // 設(shè)置圖片寬高里逆,定位
            img.style.cssText = `
                                width:${count_width}px;
                                height:${count_height}px;
                                position:absolute;
                                top: ${cont_top}px;
                                left: ${cont_left}px;`;
            img1.style.cssText = `
                                width:${count_width}px;
                                height:${count_height}px;
                                position:absolute;
                                top: ${cont_top}px;
                                left: ${cont_left}px;`;
        }

    </script>    
    </body>
</html>

效果圖:
圖片比例大于盒子比例, 等比縮放左右居中


圖片寬高比大于盒子寬高比.png

圖片比例小于盒子比例, 等比縮放上下居中


上下居中.png

圖片比例小于盒子比例, 等比縮放左右居中


左右居中.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末进胯,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子原押,更是在濱河造成了極大的恐慌胁镐,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,204評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件诸衔,死亡現(xiàn)場(chǎng)離奇詭異盯漂,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)笨农,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門就缆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人谒亦,你說我怎么就攤上這事竭宰】战迹” “怎么了?”我有些...
    開封第一講書人閱讀 164,548評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵羞延,是天一觀的道長(zhǎng)渣淳。 經(jīng)常有香客問我脾还,道長(zhǎng)伴箩,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,657評(píng)論 1 293
  • 正文 為了忘掉前任鄙漏,我火速辦了婚禮嗤谚,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘怔蚌。我一直安慰自己巩步,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,689評(píng)論 6 392
  • 文/花漫 我一把揭開白布桦踊。 她就那樣靜靜地躺著椅野,像睡著了一般。 火紅的嫁衣襯著肌膚如雪籍胯。 梳的紋絲不亂的頭發(fā)上竟闪,一...
    開封第一講書人閱讀 51,554評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音杖狼,去河邊找鬼炼蛤。 笑死,一個(gè)胖子當(dāng)著我的面吹牛蝶涩,可吹牛的內(nèi)容都是我干的理朋。 我是一名探鬼主播,決...
    沈念sama閱讀 40,302評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼绿聘,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼嗽上!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起熄攘,我...
    開封第一講書人閱讀 39,216評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤兽愤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后鲜屏,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體烹看,經(jīng)...
    沈念sama閱讀 45,661評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,851評(píng)論 3 336
  • 正文 我和宋清朗相戀三年洛史,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了惯殊。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,977評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡也殖,死狀恐怖土思,靈堂內(nèi)的尸體忽然破棺而出务热,到底是詐尸還是另有隱情,我是刑警寧澤己儒,帶...
    沈念sama閱讀 35,697評(píng)論 5 347
  • 正文 年R本政府宣布崎岂,位于F島的核電站,受9級(jí)特大地震影響闪湾,放射性物質(zhì)發(fā)生泄漏冲甘。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,306評(píng)論 3 330
  • 文/蒙蒙 一途样、第九天 我趴在偏房一處隱蔽的房頂上張望江醇。 院中可真熱鬧,春花似錦何暇、人聲如沸陶夜。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,898評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)条辟。三九已至,卻和暖如春宏胯,著一層夾襖步出監(jiān)牢的瞬間羽嫡,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,019評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工胳嘲, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留厂僧,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,138評(píng)論 3 370
  • 正文 我出身青樓了牛,卻偏偏與公主長(zhǎng)得像颜屠,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子鹰祸,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,927評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容