免费人妻精品一区二区三区-人人玩人人添人人澡东莞-很黄很色很污18禁免费-视频一区二区三区四区五区-久久99精品久久久久久9-国产97色在线 | 国-伊人七七-已婚少妇美妙人妻系列-欧美俄罗斯乱妇-奇米在线-国产精品99久久精品爆乳-欧美精品乱码视频一二专区-又大又爽又黄无码a片-粉嫩绯色av一区二区在线观看-国产爆乳无码av在线播放

深入理解和應用display屬性(一)

2016/11/2 8:34:04   閱讀:1767    發布者:1767

      Display在官方定義:規定元素應該生成的框的類型。
本文只重點分析常用的6個值:none、block、inline、inline-block、inherit、flex。
其他table、list-item等都不再推薦使用。

一、None

此元素不會被顯示。主要與visibility屬性為hidden時相區分。

1) 當元素的none時,js可以獲取此元素,但不能獲取/設置此元素的可視化屬性的值
(但可以設置自定義屬性的值),如Width、Height、background等Css屬性的值,這也就表明當元素為none時,
元素是不被瀏覽器渲染的。

2) 當元素的visibility值為hidden時,元素雖然不可見,但可以獲取/設置元素的任何值,
包含Css相關屬性。這也就表明此時的元素是被瀏覽器渲染的(在文檔流中是占有位置的),
只是處于不可見的狀態。

3) 示例代碼如下:

Css代碼:

#div01{  
                display: none; 
                width: 200px; 
                background: red; 
            } 
            #div02{ 
                visibility: hidden; 
                width: 100px; 
            } 
            #div03{  
                width: 100px; 
            }

Js/html代碼:

<div id="div01" data-name="div01" > div01</div> 
        <div id="div02" data-name="div02" > div01</div> 
        <div id="div03" > div03</div> 
        <script type="text/javascript"> 
            window.onload = function(){ 
                var div01 = document.getElementById(’div01’); 
                var div02 = document.getElementById(’div02’);  
                var div03 = document.getElementById(’div03’);  

                //output: div01:0 background:  name:div01 
                console.log( ’div01:’ + div01.offsetWidth + " background: " + 
div01.style.background + " name:" + div01.getAttribute("data-name")); //output: div02:100 name:div02 console.log( ’div02:’ + div02.offsetWidth + " name:" +
div02.getAttribute("data-name")); //output: div03:100 console.log( ’div03:’ + div03.offsetWidth); div01.style.width = 1000; div01.setAttribute("data-name","div0101"); div02.style.width = "800px"; div02.setAttribute("data-name","div0202"); div03.style.width = 800; //output: div01:0 background: name:div0101 console.log( ’div01:’ + div01.offsetWidth + " background: " + div01.style.
background + " name:" + div01.getAttribute("data-name")); //output: div02:800 name:div0202 console.log( ’div02:’ + div02.offsetWidth + " name:" +
div02.getAttribute("data-name")); //output: div03:800 console.log( ’div03:’ + div03.offsetWidth); } </script>

二、Block

設置元素為塊級元素,可應用盒子模型相關屬性。默認Width會100%,Height自適應。
Margin、padding都有效。如果沒有占寬或高的子元素存在,則高度為零。

代碼如下:

<html> 
    <head> 
        <style> 
            #div01{ 
                background: red; 
            } 
            #div02{ 
                height: 100px; 
                background: gray; 
            } 
            #div03{ 
                background: green; 
            } 
        </style> 
    </head> 
    <body> 
        <div id="div01" ></div> 
        <div id="div02" ></div> 
        <div id="div03" >div03</div> 
    </body> 
</html>

效果截圖:

 

三、inline

行內元素或者通過display:inline修飾為行內元素的都具有行內元素的行為。

1) 多個inline元素會排成一行,并列的多個inline元素之間會存在8個像素左右的間隔,
8像素間隔解決辦法:

a). Html文本有意識的都排成一行,如下代碼所示:

<a>a01</a><a>a02</a>

b). 利用margin-left:-8px,也就是marginq負值實現,也可以在外層使用letter-spaceing
和word-spaceing為負值的方式實現(此種試子元素需要重置被設置屬性)

.inline{ 
                display: inline; 
                background: red; 
                margin: 0px; 
                padding: 10px; 
                margin-left: -8px; 
            }
<div class="inline">inline01</div> 
        <div class="inline">inline02</div> 
        <div class="inline">inline03</div> 
        <div class="inline">inline04</div>

c). 包裹inline元素的外層元素加上font-size:0px和-webkit-text-size-adjust:none實現

a{ 
                background: red;   
                font-size: 14px; 
            }    
            .overWidth{ 
                white-space: nowrap; 
                border: 1px solid gray; 
                font-size: 0px; 
                -webkit-text-size-adjust: none; 
            }
<div class="overWidth" > 
            <a>a01</a> 
            <a>a000000002</a> 
        </div>

2) Inline元素的width和height無效

3) Inline元素的padding都有效,但margin左右有效,上下無效

4) Inline元素包裹inline元素,外層元素的width和height會被內部的撐開

.overWidth{ 
                display: inline; 
                border: 1px solid gray; 
            }
<div class="overWidth" > 
            <a>a01</a> 
            <a>a000000002</a> 
        </div>

5) Block/inline-block元素包裹inline元素,默認超width自動換行,height撐開。

a) 強制不換行可以通過white-space:nowrap來實現,此時超width的就會浮出來,
可以通過overflow:hidden和text-overflow:ellipsis配合實現省略顯示。

.overWidth{ 
                white-space: nowrap; 
                width: 100px; 
                border: 1px solid gray; 
                overflow: hidden; 
                text-overflow: ellipsis; 
            }
<div class="overWidth" > 
            <a>a01</a> 
            <a>a000000002</a> 
        </div>
主站蜘蛛池模板: 亚洲一区av无码少妇电影 | 国产明星裸体无码xxxx视频 | 99久久e免费热视频百度 | 国产成人无码a区精油按摩 色碰视频 | 久久天天躁夜夜躁狠狠2018 | 亚洲伊人久久成人综合网 | 欧美大片免费在线观看 | 18禁美女裸体网站无遮挡 | 精品熟女少妇a∨免费久久 亚洲欧美另类国产 | 中文字幕 人妻熟女 | 性高朝久久久久久久3小时 激情超碰 | 久久久少妇| 久久久久久久网站 | 亚洲精品午夜aaa久久久 | 风流老熟女一区二区三区 | 亚洲中文久久精品无码99 | 好男人香蕉影院 | 人人爽人人爽人人片a免费 西西4444www大胆无码 | 无码人妻精品中文字幕 | 观看av在线 | 潘金莲一级淫片aaaaaaa | 色wwwwww| 无码av免费一区二区三区 | 亚洲伊人色欲综合网 | 樱花草av| 男人天堂av网 | 玩弄丰满熟妇xxxxx性60 | 最新国产精品拍自在线播放 | 免费人成视频在线观看视频 | 婷婷看片| 亚洲国产欧美在线人成app | 在线观看免费视频一区 | 少妇无码av无码专线区大牛影院 | 对白超刺激精彩粗话av | 野花社区在线www日本 | 狠狠干2021 | 国产黄在线观看免费观看软件 | 少妇私密推油呻吟在线播放 | 亚洲人成电影在线观看天堂色 | 欧美久久久 | 99视频免费| 中文字幕超碰在线 | 国内午夜熟妇又乱又伦 | 含羞草一区二区 | 黄色91在线观看 | 免费大片av手机看片高清 | 丁香婷婷无码不卡在线 | 在线久久 | 精品亚洲欧美视频在线观看 | 最近2019免费中文第一页 | 超碰69| 久久久久久一级片 | 国产字幕av | 亚洲欧洲日产国码二区 | 国产精品一区理论片 | 日本zzjj| 日韩不卡在线视频 | 成人av一区二区三区在线观看 | 人人爱人人澡 | 无码中文字幕人妻在线一区 | 精品无码一区二区三区电影 | 国产色婷婷 | 人妻精品动漫h无码中字 | 国产精品久久婷婷六月丁香 | 97超碰人人在线 | 又大又黄又粗高潮免费 | 国产熟睡乱子伦视频观看软件 | 亚洲2021av天堂手机版 | 人妻丰满熟妇岳av无码区hd | 国产日本免费 | 伊人亚洲综合网色 | 长腿校花无力呻吟娇喘的视频 | 国产成人无码精品午夜福利a | 亚洲区视频在线观看 | 亚洲国产精品一区二区美利坚 | 亚洲 视频 一区 | 久久精品99久久香蕉国产色戒 | 精品国产一区二区三区av性色 | 无码中文字幕人妻在线一区 | 曰韩精品无码一区二区视频 | 97中文字幕| a国产 | 三上悠亚日韩精品二区 | 国产成网站18禁止久久影院 | 亚洲偷精品国产五月丁香麻豆 | 香蕉色视频 | 女人被黑人躁得好爽视频 | 无码专区狠狠躁躁天天躁 | 亚洲精品国产成人精品软件 | 欧美老熟妇喷水 | 嫩草欧美曰韩国产大片 | 一区二区三区无码免费看 | 日本japanese丰满少妇 | 欧美日日日 | 奇米成人 | 中文字幕一线产区和二线 | 爆乳2把你榨干哦ova在线观看 | 午夜亚州 | 亚洲永久无码3d动漫一区 |