日本一卡精品视频免费丨国产午夜片无码区在线播放丨国产精品成人久久久久久久丨国产亚洲日韩av在线播放不卡丨亚洲日韩av无码

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

2016/10/22 8:32:51   閱讀:1794    發(fā)布者:1794

      Display在官方定義:規(guī)定元素應(yīng)該生成的框的類(lèi)型。
本文只重點(diǎn)分析常用的6個(gè)值:none、block、inline、inline-block、inherit、flex。
其他table、list-item等都不再推薦使用。

一、None

此元素不會(huì)被顯示。主要與visibility屬性為hidden時(shí)相區(qū)分。

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

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

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

設(shè)置元素為塊級(jí)元素,可應(yīng)用盒子模型相關(guān)屬性。默認(rèn)Width會(huì)100%,Height自適應(yīng)。
Margin、padding都有效。如果沒(méi)有占寬或高的子元素存在,則高度為零。

代碼如下:

<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

行內(nèi)元素或者通過(guò)display:inline修飾為行內(nèi)元素的都具有行內(nèi)元素的行為。

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

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

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

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

.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實(shí)現(xiàn)

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無(wú)效

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

4) Inline元素包裹inline元素,外層元素的width和height會(huì)被內(nèi)部的撐開(kāi)

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

5) Block/inline-block元素包裹inline元素,默認(rèn)超width自動(dòng)換行,height撐開(kāi)。

a) 強(qiáng)制不換行可以通過(guò)white-space:nowrap來(lái)實(shí)現(xiàn),此時(shí)超width的就會(huì)浮出來(lái),
可以通過(guò)overflow:hidden和text-overflow:ellipsis配合實(shí)現(xiàn)省略顯示。

.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>
主站蜘蛛池模板: 网站色| 亚洲中文字幕无码不卡电影| 2019精品手机国产品在线| 国产mv欧美mv日产mv免费| 无码h片在线观看网站| www日本高清| 4444亚洲人成无码网在线观看| 日韩一级片免费看| 中老年熟妇激情啪啪大屁股| 开心色怡人综合网站| 91黄色短视频| 4438xx亚洲最大五色丁香| 亚洲综合色区另类aⅴ| 久久五月精品中文字幕| 日美女逼逼| 爆爽久久久一区二区又大又黄又嫩| 亚洲看片lutube在线观看| 免费观看羞羞视频网站| 99久久婷婷国产综合精品草原| 熟女少妇在线视频播放| 91在线网站| 高清无码午夜福利视频| 欧美日韩一区视频| 天堂中文最新版在线官网在线| 精品人妻无码一区二区三区蜜桃一| 人人妻人人爽人人做夜欢视频 | 国产精品免费拍拍10000部2| 国产精品无码久久综合| 成人欧美一区二区三区黑人一| 久久久av男人的天堂| 亚洲日韩乱码中文无码蜜桃臀网站 | 人妻无码不卡中文字幕系列| 九色国产精品视频| 强开小婷嫩苞又嫩又紧视频| 无码人妻精品中文字幕| 国产r级在线| 亚洲日本中文字幕乱码在线电影 | 久久亚洲精品无码va白人极品|