網(wǎng)頁(yè)簡(jiǎn)單布局之結(jié)構(gòu)與表現(xiàn)原則分享

結(jié)構(gòu)與表現(xiàn)相關(guān)內(nèi)容簡(jiǎn)介
html結(jié)構(gòu) css表現(xiàn) javascrip行為 網(wǎng)頁(yè)布局要考慮到結(jié)構(gòu),表現(xiàn),行為分離原則,首先重點(diǎn)放在結(jié)構(gòu)和語(yǔ)義化上面,再考慮CSS,JS等,便于后期維護(hù)和分析……
結(jié)構(gòu)與表現(xiàn)相分離的思想
- 初級(jí)的開(kāi)發(fā)人員思路及制作方法:div層層嵌套;
- 中級(jí)的開(kāi)發(fā)人員思路及制造方法:去掉多余的div,進(jìn)行簡(jiǎn)化;
- 高級(jí)的開(kāi)發(fā)人員思路及制造方法:最大化的簡(jiǎn)化html的結(jié)構(gòu),然后用css進(jìn)行設(shè)置,減少html與css的契合度。
步驟:
先按結(jié)構(gòu)和語(yǔ)義編寫(xiě)代碼
然后進(jìn)行css樣式設(shè)置
減少HTML與CSS契合度
overflow:
visible 默認(rèn)值。內(nèi)容不會(huì)被修剪,會(huì)呈現(xiàn)在元素框之外。
hidden 內(nèi)容會(huì)被修剪,并且其余內(nèi)容是不可見(jiàn)的。
scroll 內(nèi)容會(huì)被修剪,但是瀏覽器會(huì)顯示滾動(dòng)條以便查看其余的內(nèi)容。
auto 如果內(nèi)容被修剪,則瀏覽器會(huì)顯示滾動(dòng)條以便查看其余的內(nèi)容。
inherit 規(guī)定應(yīng)該從父元素繼承 overflow 屬性的值。
text-indent文本縮進(jìn)到目標(biāo)位置,可以不要給文本再另外套標(biāo)簽。減少冗余代碼
拿到一個(gè)網(wǎng)頁(yè)設(shè)計(jì)圖的時(shí)候,首先關(guān)注網(wǎng)頁(yè)的文字內(nèi)容以及內(nèi)容模塊間的關(guān)系。
把重點(diǎn)放在編寫(xiě)語(yǔ)義化的html代碼上,而不要過(guò)多考慮設(shè)計(jì)圖上的樣式,
等到html按內(nèi)容編寫(xiě)完成之后,再考慮樣式的實(shí)現(xiàn)。
在不改變現(xiàn)有結(jié)構(gòu)的基礎(chǔ)上,完成設(shè)計(jì)圖要求的視覺(jué)效果
margin可以是負(fù)值,通過(guò)負(fù)值,可以使該內(nèi)容進(jìn)行移動(dòng)!實(shí)現(xiàn)四個(gè)方向的移動(dòng)。
在結(jié)構(gòu)(HTML)和樣式(css)中,可以先把內(nèi)容通過(guò)HTML寫(xiě)出來(lái),再利用margin移動(dòng)位置,實(shí)現(xiàn)排版,降低樣式和結(jié)構(gòu)的耦合,并且減少代碼
網(wǎng)頁(yè)換膚及總結(jié)
盡量減少html對(duì)css的依賴
網(wǎng)頁(yè)換膚:相同的html結(jié)構(gòu),不同的css樣式
下面是一些灰牛WEB同學(xué)的分享
一開(kāi)始我們接觸網(wǎng)頁(yè)制作的時(shí)候,就了解到html代表結(jié)構(gòu)、css代表樣式、javascript代表行為,網(wǎng)頁(yè)制作中,我們一直強(qiáng)調(diào)結(jié)構(gòu)與表現(xiàn)相分離的原則,這里面的結(jié)構(gòu)一般指HTML,此外分離是說(shuō)把它們寫(xiě)在不同的文件加以引用嗎?當(dāng)然不是,在這里的學(xué)習(xí)中了解到,分離不單是一種方法更是一種思想,簡(jiǎn)而言之,一個(gè)平面二維坐標(biāo),其中x軸代表技術(shù)發(fā)展,y軸代表網(wǎng)頁(yè)制作需求,分離就是根據(jù)根據(jù)技術(shù)發(fā)展和我們的網(wǎng)頁(yè)制作需求完成的!
舉例:比方說(shuō)我們蓋房子,html就相當(dāng)房子的結(jié)構(gòu),css相當(dāng)于后期的裝修,網(wǎng)頁(yè)都是基于一張效果來(lái)完成的,在我們?yōu)g覽網(wǎng)頁(yè)的時(shí)候,根據(jù)效果圖不同,樣式不同,所以我們?yōu)g覽的頁(yè)面是五花八門(mén)的,那么我們?nèi)绾蝸?lái)布局好網(wǎng)頁(yè)?首先不要考慮過(guò)多的css樣式,盡量讓我們的html結(jié)構(gòu)合理簡(jiǎn)潔和語(yǔ)義化,然后再添加完善css樣式!
當(dāng)我們拿到頁(yè)面時(shí),不同的制作者對(duì)結(jié)構(gòu)結(jié)構(gòu)樣式有不同的鏈接,根據(jù)這個(gè)結(jié)構(gòu)樣式了解深度的不同,暫定劃分為:初級(jí)、中級(jí)、高級(jí)三個(gè)不同的層次;
比方說(shuō)這樣一個(gè)常見(jiàn)的對(duì)話框,有3個(gè)單元,首先我們需要完成一個(gè)單元,另外的進(jìn)行CTRL+V;如果是初級(jí)制作者拿到頁(yè)面后,一般按照上面的方框進(jìn)行劃分,一個(gè)大的div里面包含2個(gè)小的div,左右浮動(dòng),左側(cè)放img,右側(cè)放p,h等標(biāo)簽,至于時(shí)間因子通過(guò) position屬性定位實(shí)現(xiàn),那下面就用代碼說(shuō)明下
<div class="demo1"> <div class="fl"> <img src="../../images/head02.jpg" alt=""> </div> <div class="fr"> <span>10分鐘前</span> <h6>漸行漸遠(yuǎn)漸無(wú)書(shū)</h6> <p> 你是不是每天腦子里盤(pán)踞許多揮之不去的想法覺(jué)得自己很忙,仔細(xì)想想又不知道自己真正地在忙些什么,而養(yǎng)成良好的習(xí)慣,照顧好自己,追隨自己的夢(mèng)想,才能提高生產(chǎn)力,這也意味著改善你與家人和朋友的關(guān)系,因?yàn)楫?dāng)你改變時(shí),你周圍的一切都改變了,高效能的人有哪些習(xí)慣值得我們學(xué)習(xí)? </p> </div> </div> <div class="demo2"> <img src="../../images/head02.jpg" alt=""> <div class="fr"> <span>10分鐘前</span> <h6>漸行漸遠(yuǎn)漸無(wú)書(shū)</h6> <p> 你是不是每天腦子里盤(pán)踞許多揮之不去的想法覺(jué)得自己很忙,仔細(xì)想想又不知道自己真正地在忙些什么,而養(yǎng)成良好的習(xí)慣,照顧好自己,追隨自己的夢(mèng)想,才能提高生產(chǎn)力,這也意味著改善你與家人和朋友的關(guān)系,因?yàn)楫?dāng)你改變時(shí),你周圍的一切都改變了,高效能的人有哪些習(xí)慣值得我們學(xué)習(xí)? </p> </div> </div> <div class="demo3"> <img src="../../images/head02.jpg" alt=""> <span class="time">10分鐘前</span> <h6>漸行漸遠(yuǎn)漸無(wú)書(shū)</h6> <p> 你是不是每天腦子里盤(pán)踞許多揮之不去的想法覺(jué)得自己很忙,仔細(xì)想想又不知道自己真正地在忙些什么,而養(yǎng)成良好的習(xí)慣,照顧好自己,追隨自己的夢(mèng)想,才能提高生產(chǎn)力,這也意味著改善你與家人和朋友的關(guān)系,因?yàn)楫?dāng)你改變時(shí),你周圍的一切都改變了,高效能的人有哪些習(xí)慣值得我們學(xué)習(xí)? </p> </div> </div>
=>3個(gè)不同的demo代表3種不同的頁(yè)面結(jié)構(gòu)||書(shū)寫(xiě)頁(yè)面結(jié)構(gòu)公共部分展示:
/*reset*/ body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td{margin: 0;padding: 0;list-style: none;font:12px/1.5 "Arial", "sans-serif", "微軟雅黑", "宋體", "Tahoma"} /*公共樣式*/ .demo1,.demo2{ width: 600px; margin-top: 20px; overflow: hidden; margin-bottom: 20px; } p{ text-align: justify; text-indent: 2em; line-height: 24px; }
=>初級(jí)制作者css
/*初級(jí)*/ .demo1{ width: 600px; margin-top: 20px; overflow: hidden; } .demo1 .fl{ width: 100px; float: left; } .demo1 .fl img{ margin-left: 20px; padding: 10px; border: 1px solid #ccc; } .demo1 .fr{ width:488px; float: right; border: 1px solid #ccc; position: relative; padding: 5px; } .demo1 .fr span{ position: absolute; right:18px; top: 5px; }
=>中級(jí)制作者css,相較于初級(jí)進(jìn)行了結(jié)構(gòu)簡(jiǎn)化,去掉了左側(cè)的div,保留了右邊的部分;
/*中級(jí)*/ .demo2 .fr{ width:488px; float: right; border: 1px solid #ccc; position: relative; padding: 5px; } .demo2 .fr span{ position: absolute; right:18px; top: 5px; } .demo2 img{ margin-left: 20px; padding: 10px; border: 1px solid #ccc; }
=>高級(jí)制作者css:先按照結(jié)構(gòu)和語(yǔ)義編寫(xiě)代碼,然后再進(jìn)行css樣式設(shè)置,減少了css與html的契合度(文檔移動(dòng),圖像移出,定位屬性)
/*高級(jí)*/ .demo3{ border: 1px solid #ccc; width: 488px; margin-left: 100px; padding: 5px; position: relative; } .demo3 img{ float: left; margin:-6px 0 0 -86px; padding: 10px; border: 1px solid #CCCCCC; } .demo3 span{ position: absolute; top: 10px; right: 20px; }
結(jié)論:拿到一張網(wǎng)頁(yè)設(shè)計(jì)圖的時(shí)候,首先要觀察文字和內(nèi)容模塊之間的關(guān)系,重點(diǎn)放在編寫(xiě)語(yǔ)義化html代碼上,而不要過(guò)多地考慮設(shè)計(jì)間的布局樣式,等到html代碼編輯完成,再考慮如何實(shí)現(xiàn),力求在不改變現(xiàn)有頁(yè)面結(jié)構(gòu)的基礎(chǔ)上完成設(shè)計(jì)圖稿要求呈現(xiàn)的視覺(jué)效果!(點(diǎn)擊下載完整網(wǎng)頁(yè)簡(jiǎn)單布局之結(jié)構(gòu)與表現(xiàn)原則代碼)
以上就是網(wǎng)頁(yè)簡(jiǎn)單布局之結(jié)構(gòu)與表現(xiàn)原則分享的詳細(xì)內(nèi)容,更多關(guān)于網(wǎng)頁(yè)簡(jiǎn)單布局之結(jié)構(gòu)與表現(xiàn)原則的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
15 個(gè)為編程初學(xué)者準(zhǔn)備的網(wǎng)站(都是國(guó)外的一些網(wǎng)站)
今天的文章,我們將分享15個(gè)可以學(xué)習(xí)編程的網(wǎng)站,這些網(wǎng)站上提供了很多編程教程,圖書(shū)以及編程練習(xí),希望對(duì)你有用2024-11-02web開(kāi)發(fā)中的長(zhǎng)度單位小結(jié)
這篇文章主要介紹了web開(kāi)發(fā)中的長(zhǎng)度單位主要包括px,pt,em等,需要的朋友可以參考下2023-08-06網(wǎng)頁(yè)前端開(kāi)發(fā)的一些尺寸單位(px,rem單位)
px單位是絕對(duì)單位,一般用于pc端網(wǎng)頁(yè)開(kāi)發(fā),因?yàn)槭墙^對(duì)單位所以在移動(dòng)端上的使用體驗(yàn)并不是很好,rem它是描述相對(duì)于當(dāng)前根元素字體尺寸,是相對(duì)單位,它可以根據(jù)根元素的變換而2023-08-06WEB前端優(yōu)化必備js/css壓縮工具YUI-compressor詳解與集成用法
壓縮工具層次不窮,各有優(yōu)點(diǎn),選擇適合的壓縮工具為將來(lái)做項(xiàng)目開(kāi)發(fā)使用是一件很重要的事情?。≡谶@介紹YUI-compressor,需要的朋友可以參考下2023-06-21html,css,javascript是怎樣變成頁(yè)面的
瀏覽器是多進(jìn)程的,有瀏覽器主進(jìn)程,網(wǎng)絡(luò)進(jìn)程,渲染進(jìn)程,插件進(jìn)程等,在將html,css,javascript解析成一個(gè)頁(yè)面的時(shí)候,就需要多個(gè)進(jìn)程的分工合作2023-05-01- 本文為大家整理了常用的文件對(duì)應(yīng)的MIME類型,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-04-25
postman中form-data、x-www-form-urlencoded、raw、binary的區(qū)別介紹
這篇文章介紹了postman中form-data、x-www-form-urlencoded、raw、binary的區(qū)別,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-12-28網(wǎng)頁(yè)中使用Unicode字符的介紹(&#,\u等)
國(guó)際組織制定了可以容納世界上所有文字和符號(hào)的字符編碼方案,稱為Unicode,是通用字符集Universal Character Set的縮寫(xiě),用以滿足跨語(yǔ)言、跨平臺(tái)進(jìn)行文本轉(zhuǎn)換、處理的要求2021-11-27前端實(shí)現(xiàn)字符串GBK與GB2312的編解碼(小結(jié))
這篇文章主要介紹了前端實(shí)現(xiàn)字符串GBK與GB2312的編解碼(小結(jié)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2020-12-02告別硬編碼讓你的前端表格自動(dòng)計(jì)算的實(shí)例代碼
這篇文章主要介紹了告別硬編碼讓你的前端表格自動(dòng)計(jì)算,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-27