您好,登錄后才能下訂單哦!
本篇內(nèi)容介紹了“CSS中的position和z-index屬性怎么使用”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
深入理解CSS中的position定位和z-index屬性
由于平時(shí)不太用到,所以過去寫CSS的時(shí)候?qū)τ趐osition屬性的absolute、relative值理解比較模糊,對(duì)于z-index的層疊更是摸不著頭腦,除了理解的因素外,各個(gè)瀏覽器的不同解析結(jié)果也是一個(gè)大問題。今天仔細(xì)閱讀了一下CSS文檔,總算是對(duì)盒模型的浮動(dòng)、定位有了比較深刻的理解。
我們?cè)趯?shí)踐中很有可能遇到這樣的問題:
1、做一個(gè)橫向?qū)Ш?,然后鼠?biāo)經(jīng)過之后出現(xiàn)下拉菜單,那么這個(gè)下拉菜單的位置控制就是一個(gè)關(guān)鍵;
2、我們想在一個(gè)正常的頁面布局中放入幾個(gè)浮在頁面上的氣泡提示,這時(shí)既不想讓氣泡提示破壞正常的文檔布局,又不想氣泡提示的定位在不同的瀏覽器中到處亂飄。
3、當(dāng)我們?cè)谝痪湔5奈谋局胁迦胍粋€(gè)小圖標(biāo)的話,一般會(huì)使用
◆relative:相對(duì)定位。這個(gè)屬性值保持對(duì)象所在文檔流中的位置,也就是說它具有和static相同的呈現(xiàn)方式,它同樣占有在文檔流中的固定位置,后面的對(duì)象不會(huì)侵占或覆蓋;與static屬性值不同的是,設(shè)置了relative的對(duì)象,可以通過top,left,right,bottom屬性設(shè)定自己的新顯示位置,這4個(gè)屬性的取值是相對(duì)于文檔流的前一個(gè)對(duì)象的,你可以自由設(shè)置這4個(gè)屬性偏移到新的位置而不對(duì)文檔流中的其他對(duì)象產(chǎn)生任何影響,原來的頁面呈現(xiàn)仍然會(huì)我行我素:
◆absolute:絕對(duì)定位。和relative不同的是,這個(gè)屬性值會(huì)將當(dāng)前對(duì)象拖出文檔流,后面的對(duì)象會(huì)占有原來的位置,也就是說,當(dāng)前對(duì)象的呈現(xiàn)是獨(dú)立顯示的,但是它的位置在指定top,left,right,bottom任一屬性之前仍是有繼承性的,這時(shí)的4個(gè)屬性的取值是相對(duì)于瀏覽器的,和文檔流無關(guān)了。如果把示例中的B區(qū)域設(shè)定為absolute而不指定4個(gè)位置屬性,通過設(shè)定margin來改變它的相對(duì)位置,用這個(gè)方法可以解決前面提到的問題2。
提示a:蘇昱的CSS2.0手冊(cè)中提到relative和absolute定位的滾動(dòng)條區(qū)別不是絕對(duì)的,至少在firefox、opera和safari中滾動(dòng)條該出現(xiàn)還是會(huì)出現(xiàn)。
提示b:屬性值為absolute對(duì)象的z-index屬性可以設(shè)置層疊顯示的次序,它是直接有效的;
而屬性值為relative對(duì)象的z-index屬性在設(shè)置時(shí)要小心,把當(dāng)前對(duì)象的z-index設(shè)置為-1是不行的,在firefox中它會(huì)無法顯示,必須設(shè)置為0以上,我們?nèi)绻胱寗e的對(duì)象擋住它,只有將其他對(duì)象也設(shè)置position為relative,并將z-index屬性取一個(gè)比它大的值即可。
上面的表述不知道也許不是很清晰,具體的理解還是要自己親自動(dòng)手操作一下。
這樣看來,前面的問題就有解了,問題3我們可以根據(jù)設(shè)計(jì)的要求將其設(shè)置為相對(duì)或絕對(duì)定位;
問題1的解決方法也有很多,個(gè)人推薦使用有語義的dl,dt,dd來實(shí)現(xiàn),而且這個(gè)方法在不同瀏覽器中的表現(xiàn)基本相同(已在ie,firefox,opera,safari中測(cè)試),僅在top的屬性上有幾像素的差異,由于時(shí)間關(guān)系我只能給出自己測(cè)試時(shí)的代碼以供參考:
◆示例代碼:
body{ color:#fff; font-size:12px; } ulli{ float:left; height:30px; background-color:#99CC99; margin:010px; padding:0; border:1pxsolid#c30; width:100px; } ullidiv{ border:1pxsolid#f00; background-color:#996666; width:100px; height:100px; position:absolute; margin-top:15px; margin-left:-1px; *margin-left:-79px; } ullidl, ullidldt, ullidldd{ margin:0; padding:0; } ullidldd{ border:1pxsolid#f00; background-color:#996666; width:100px; height:100px; position:absolute; margin-top:11px; *margin-top:10px; margin-left:-1px; } <ul> <li> 標(biāo)題-#text <div> 下拉菜單-div div> li> <listylelistyle="position:relative;">列表bli> <li>列表cli> <li> <dl> <dt>標(biāo)題-dtdt> <dd>下拉菜單-dddd> dl> li> ul>
“CSS中的position和z-index屬性怎么使用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。