楊曉姍
摘?要:布局對網(wǎng)頁的作用類似于設(shè)計圖對地產(chǎn)開發(fā)商的作用,制作商務(wù)網(wǎng)頁的首要內(nèi)容是對網(wǎng)頁進行布局。常見的布局方式有:表格布局、框架布局、層布局,鑒于以上布局方式均存在一定的缺陷逐漸退出歷史潮流。目前流行的布局方式是DIV+CSS來制作頁面,DIV主要解決網(wǎng)頁中的元素(如文字、圖片、表格、音視頻等)放置在網(wǎng)頁顯示位置的問題,而CSS主要解決網(wǎng)頁元素美觀性的問題。本文主要探討DIV+CSS布局方式用法及要注意的問題。
關(guān)鍵詞:DIV+CSS;浮動布局;定位布局
一個商務(wù)網(wǎng)頁是否吸引用戶,布局至關(guān)重要。所謂布局就是對網(wǎng)頁元素進行定位,網(wǎng)頁整體結(jié)構(gòu)是上中下還是左中右,網(wǎng)頁的LOGO、導(dǎo)航、網(wǎng)頁標(biāo)題、網(wǎng)頁核心內(nèi)容、版權(quán)信息等內(nèi)容顯示的位置。鑒于表格布局導(dǎo)致表格標(biāo)簽的嵌套瀏覽器解析較慢,框架布局不夠靈活,DIV+CSS布局方式逐漸成為主流,DIV實現(xiàn)把頁面進行切割,不同的DIV放置不同的內(nèi)容,CSS實現(xiàn)對內(nèi)容進行美化,如添加背景色、設(shè)置不同塊之間的間距等等。
1 DIV+CSS的概念
DIV是HTML語言中的一個標(biāo)簽元素即
,該標(biāo)簽代表一個容器本身沒有實際意義,是一個塊級元素,在該標(biāo)簽中可以放置文字、圖片、鏈接、音樂、div等,一個頁面可以通過多個div標(biāo)簽的嵌套實現(xiàn)對網(wǎng)頁進行分割,通過設(shè)置div中的內(nèi)容與div的內(nèi)邊距、不同div之間的外邊距來對頁面進行布局。CSS(Cascading Style Sheets)指層疊樣式表,作用是對網(wǎng)頁元素進行美化,CSS可以出現(xiàn)在HTML標(biāo)簽行中、HTML的
標(biāo)簽中、外部樣式表三個位置,在DIV+CSS布局中常常把CSS獨立形成一個.css文件,實現(xiàn)與HTML文件完全分離,可以實現(xiàn)樣式表的重復(fù)使用、網(wǎng)頁的結(jié)構(gòu)與表現(xiàn)可以實現(xiàn)完全分離。CSS中主要有類選擇器、ID選擇器、復(fù)合選擇器和標(biāo)簽選擇器四種,優(yōu)先級順序為:復(fù)合選擇器>ID選擇器>類選擇器>標(biāo)簽選擇器,復(fù)合選擇器的優(yōu)先級最高、標(biāo)簽選擇器的優(yōu)先級最低,ID選擇器只能使用一次,類選擇器可以重復(fù)使用,在實際制作網(wǎng)頁過程中要根據(jù)需求靈活選擇CSS選擇器的類型。2 DIV+CSS的運用
2.1 標(biāo)準(zhǔn)布局
標(biāo)準(zhǔn)布局是指網(wǎng)頁元素按HTML代碼的順序自上而下或自左向右逐步分布的,就像流水一樣,我們將這種流動方式稱為標(biāo)準(zhǔn)流或文檔流。標(biāo)準(zhǔn)流布局具有以下兩個比較典型的特征。塊級元素會在所處的包含元素內(nèi)自上而下按順序垂直分布。因為在默認狀態(tài)下,不管把塊級元素的寬度設(shè)置多窄,它都會獨占一行。內(nèi)聯(lián)元素會在所處的包含元素內(nèi)自左向右水平分布顯示,超出一行后,會自動自上而下?lián)Q行顯示,然后繼續(xù)自左向右按順序流動,依次類推。
2.2 浮動布局
標(biāo)準(zhǔn)布局不能完全滿足網(wǎng)頁設(shè)計的需求,有時設(shè)計需要把兩個或者多個DIV在一行顯示,此時需用到浮動布局,浮動布局的主要作用是打破標(biāo)準(zhǔn)流布局的自上而下、自左向右的布局方式,使得塊元素不獨占一行。此時可有多種方式實現(xiàn)效果。
方法一:left、rihgt同時左浮動或者右浮動,#left #right{float:left;};方法二:left左浮動、right右浮動,即#left{float:left;},#right{flaot:right};方法三:left設(shè)置寬度和左浮動,right設(shè)置左外邊距值,即#left{width:200px;float:left;},#right{margin-left:200px;};方法四:類似與方法三,right設(shè)置右浮動,left設(shè)置右外邊距。設(shè)置浮動后會給right后面的元素產(chǎn)生影響,為了清除這種影響通常做法是在right后添加一個空白div1,并設(shè)置改空白div的樣式#div1{clear:both;}。
2.3 定位布局
定位布局分為相對定位和絕對定位,主要是通過元素的position、z-index、overflow、clip屬性來實現(xiàn),相對定位通過設(shè)置水平位置和垂直位置來實現(xiàn),其在標(biāo)準(zhǔn)流中的位置仍然存在。絕對定位的使用其祖先元素必須設(shè)置定位屬性,在絕對定位中,標(biāo)準(zhǔn)流中其他元素的布局對絕對定位的元素不影響,所以會導(dǎo)致絕對定位的元素覆蓋其他元素,這時就通過設(shè)置z-index屬性來控制元素的層級順序?qū)崿F(xiàn)想要的效果。在實際應(yīng)用中相對定位很少單獨使用,相對定位一般作為祖先元素的定位,從而輔助設(shè)置其子孫元素的絕對定位。
3 DIV+CSS布局要注意的問題
頁面的整體布局一般都采用標(biāo)準(zhǔn)流方式,當(dāng)頁面中有多個塊元素要在一行顯示時,可通過浮動布局和定位布局來實現(xiàn),采用浮動布局,要注意清除對后面元素的影響,定位布局通常設(shè)置祖先元素的相對定位作為參考對象,即祖先元素必須擁有定位position屬性,屬性值為relative或absolute,其次要設(shè)置絕對定位的坐標(biāo)值,參考點是祖先元素4個頂點中的任意一點,只能設(shè)置兩個值即水平方向:left或right;垂直方向:top或bottom。
4 結(jié)語
使用DIV+CSS布局可以完美地實現(xiàn)結(jié)構(gòu)、表現(xiàn)的分離,DIV的主要作用是把頁面分割成一個個區(qū)域,然后運用標(biāo)準(zhǔn)布局、浮動布局、定位布局三種布局方式實現(xiàn)頁面的結(jié)構(gòu),CSS對設(shè)置每一個區(qū)域的樣式以及區(qū)域內(nèi)網(wǎng)頁元素的樣式。DIV+CSS的布局方式使得網(wǎng)頁的開發(fā)速度、執(zhí)行效率以及代碼的可讀性都有了很大的提高,但如果要熟練的運用DIV+CSS的布局完整頁面需要不停的學(xué)習(xí)和積累經(jīng)驗。
參考文獻:
[1]李居蘭.談網(wǎng)頁設(shè)計常用的布局方法[J].計算機產(chǎn)品與流通,2019(11):253.
[2]黃楚鵬.基于CSS頁面布局的網(wǎng)頁設(shè)計[J].電腦知識與技術(shù),2017,13(04):45+55.
[3]雷燁.運用DIV+CSS技術(shù)對網(wǎng)頁進行布局[J].電腦知識與技術(shù),2016,12(07):212-213.