主頁(yè) > 知識(shí)庫(kù) > HTML中img標(biāo)簽只顯示圖片中心位置的方法(三種方法)

HTML中img標(biāo)簽只顯示圖片中心位置的方法(三種方法)

熱門(mén)標(biāo)簽:高德地圖標(biāo)注廁所 威海語(yǔ)音外呼系統(tǒng)平臺(tái) 地圖標(biāo)注員工作內(nèi)容 地圖標(biāo)注沿海城市房?jī)r(jià) 江西ai電銷機(jī)器人如何 通遼地圖標(biāo)注app 西安金倫外呼系統(tǒng) 中國(guó)地圖標(biāo)注城市的 智能語(yǔ)音電銷機(jī)器人客戶端

html中 img標(biāo)簽顯示圖片中心的方法目前知道三種,在此記錄一下

第一種:用到css的clip:rect(top right bottom left);用法,需要配合position: absolute使用:如下

<img src="http://img2.utuku.china.com/640x0/news/20170210/77b8b5ca-11d3-4307-9a93-c12df5eb1a35.jpg"
     style="position: absolute;clip: rect(0px,250px,200px,50px);width: 300px;height: 200px">

設(shè)置圖片的width和height相當(dāng)于圖片實(shí)際寬高的等比例縮放,再用rect方法來(lái)設(shè)置圖片的剪切范圍。

- 第二種:用img的background屬性:

<style type="text/css">
        img {
            background-image: url(http://img2.utuku.china.com/640x0/news/20170210/77b8b5ca-11d3-4307-9a93-c12df5eb1a35.jpg);//設(shè)置背景圖片
            background-repeat: no-repeat;//背景圖像將僅顯示一次。
            background-attachment: scroll;//
            background-position: -50px 0px;//設(shè)置背景圖片的的偏移量,這個(gè)-50相當(dāng)于背景整體向左偏移50,就可以顯示圖片的中心
            background-size: 300px 200px;////設(shè)置背景圖片的大小,相當(dāng)于圖片實(shí)際寬高等比例餓縮放的
            background-color: transparent;//
            width: 200px;//
            height: 200px;//
        }
    </style>

用背景來(lái)控制圖片顯示中心位置,需要設(shè)置背景按照?qǐng)D片的真實(shí)寬高等比縮放,然后偏移背景的移動(dòng)量來(lái)控制圖片的寬高,這個(gè)需要注意的是不能圖片的src,img標(biāo)簽不設(shè)置src時(shí)候,顯示的圖片會(huì)出現(xiàn)一條灰色的邊框,而且沒(méi)有辦法去掉,border:0px也沒(méi)有作用,我之前的解決辦法是放一張默認(rèn)的全透明的圖片在src中,就可以解決了。

第三種:在div中包含img,用div的overflow: hidden;來(lái)控制,用起來(lái)比較靈活,

<div style="width: 100px;height: 100px;overflow: hidden">
<img src="http://img2.utuku.china.com/640x0/news/20170210/77b8b5ca-11d3-4307-9a93-c12df5eb1a35.jpg" style="position: relative" id="img_id">
</div>
<script>
    var img = document.getElementById("img_id");
    var image = new Image();
    var realWidth = 0;//儲(chǔ)存圖片實(shí)際寬度
    var realHeight = 0;//儲(chǔ)存圖片實(shí)際高度
    //獲取圖片的寬高
    image.src = "http://img2.utuku.china.com/640x0/news/20170210/77b8b5ca-11d3-4307-9a93-c12df5eb1a35.jpg";
    //加載成功的處理
    image.onload = function () {
        realWidth = image.width;//獲取圖片實(shí)際寬度
        realHeight = image.height;//獲取圖片實(shí)際高度
        //讓img的寬高相當(dāng)于圖片實(shí)際寬高的等比縮放,然后再偏移
        if (realWidth > realHeight){
            img.width = (100/realHeight)*realWidth;//等比縮放寬度
            img.height = 100;//跟div高度一致
            img.style.left = '-' + ((100/realHeight)*realWidth-100)/2 + 'px';//設(shè)置圖片相對(duì)自己位置偏移為img標(biāo)簽的寬度-高度的一半
        }else if (realWidth < realHeight){
            img.width =100 ;//跟div高度一致
            img.height = (100/realWidth)*realHeight;//等比縮放高度
            img.style.top = '-' + ((100/realWidth)*realHeight-100)/2 + 'px';//設(shè)置圖片相對(duì)自己位置偏移為img標(biāo)簽的高度-寬度的一半
        }else {
            img.width =100 ;
            img.height = 100;
        }
    };
    //圖片加載失敗的處理
    img.onerror = function () {
        img.src = "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1492076382452&di=04ebd6c4688b2ffbd8ae18e685234704&imgtype=0&src=http%3A%2F%2Fd.hiphotos.baidu.com%2Fzhidao%2Fwh%253D450%252C600%2Fsign%3D0c96dc86da33c895a62b907fe4235fc6%2F0823dd54564e9258d2bb2dff9f82d158ccbf4e17.jpg";
        img.width =100 ;
        img.height = 100;
    }
</script>

上面注釋已經(jīng)很清楚了,主要是div控制了大小,img標(biāo)簽根據(jù)div的大小來(lái)調(diào)節(jié)自身的大小。在進(jìn)行偏移,從而達(dá)到顯示圖片中間部分的圖片。個(gè)人覺(jué)得第三種方法比較好用。

以上所述是小編給大家介紹的HTML中img標(biāo)簽只顯示圖片中心位置的方法(三種方法),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

標(biāo)簽:青海 營(yíng)口 崇左 晉中 河池 北海 阜陽(yáng) 眉山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《HTML中img標(biāo)簽只顯示圖片中心位置的方法(三種方法)》,本文關(guān)鍵詞  HTML,中,img,標(biāo)簽,只,顯示,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《HTML中img標(biāo)簽只顯示圖片中心位置的方法(三種方法)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于HTML中img標(biāo)簽只顯示圖片中心位置的方法(三種方法)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章