HTML5+CSS3學習筆記(二) 頁面佈局:HTML5新元素及其特性

HTML5的語義化標籤以及屬性,可讓開發者很是方便地實現清晰的web頁面佈局,加上CSS3的效果渲染,快速創建豐富靈活的web頁面顯得很是簡單。css

本次學習HTML5的新標籤元素有:html

<header>定義頁面或區段的頭部;web

<footer>定義頁面或區段的尾部;瀏覽器

<nav>定義頁面或區段的導航區域;ide

<section>頁面的邏輯區域或內容組合;工具

<article>定義正文或一篇完整的內容;佈局

<aside>定義補充或相關內容;post

學習這些標籤最好的方法固然就是試着使用它們。雖然如今有不少現成的網頁佈局的模板能夠方便的拿來用,可是對於初學者來講,本身實現簡單的頁面佈局絕對是有必要的。這裏經過一個簡單的頁面佈局的例子,來展現上述標籤的使用方法。學習

示例:模仿博客首頁佈局字體

實現如圖2-1的網頁結構,這是一個很是典型的博客頁面:頭部、尾部、水平導航欄、側邊欄導航以及內容。

圖2-1

在圖2-1中已經看到,相應標籤實現的區域用名稱標註了出來,好比頭部Header

在編寫頁面前,有必要說一下:頁面元素由HTML5實現,而元素的顯示效果是CSS3渲染的,CSS3的代碼能夠和HTML5的代碼放在同一個文件,也能夠是獨立的文件,只要在HTML5文件裏引用便可。建議最好各自是獨立的文件,這樣的好處有:

1)符合單一職責原則:HTML5頁面就負責管理元素,而CSS3文件只負責對相應HTML5文件顯示效果的渲染,相互獨立,互不相交。

2)下降頁面的複雜度,便於維護:試想,當頁面的元素數量增到不少的時候,同時在一個頁面裏管理元素和元素的顯示屬性,可讀性是該有多差,後期的維護會很蛋疼。

3)加快瀏覽器的加載速度:第2)點的另一個好處,簡單的頁面天然加載更快。

固然,若是就是習慣HTML5+CSS3放在一個文件裏,也何嘗不可,這裏也只是建議。

下面來具體實現圖2-1。

分爲兩個部分:1)HTML5文件;2)CSS3文件

一.HTML5部分

1.HTML5的文檔聲明

新建index.html文件,若是用的網頁編寫工具已經支持HTML5文件類型,那麼,應該生成以下的HTML5模板:

複製代碼
 1 <!DOCTYPE html>  2 <html lang="en-US">  3 <head>  4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  5 <title>Layout TEST</title>  6 </head>  7  8 <body>  9 </body> 10 </html>
複製代碼

若是網頁編寫工具暫時不支持HTML5也不要緊,本身寫這幾行代碼也很簡單。

說明:第一行:<!DOCTYPE html>是HTML5對文檔類型的簡化,化繁爲簡;(文檔類型的做用:驗證器依據它來判斷該採用何種規則去驗證代碼;強制瀏覽器以標準模式渲染頁面)

2.頭部

<header>標籤實現

<header id="page_header"> <h1>Header</h1> </header>

說明:1)header不能喝h1,h2,h3這些標題混爲一談。<header>能夠包含從公司logo到搜索框在內的各式各樣的內容。例子中只含有標題。

2)同一個頁面能夠包含多個<header>元素。每一個獨立的區塊或文章均可以含有本身的<header>.因此示例中爲<header>添加惟一標示id屬性,便於CSS3中靈活的渲染。在CSS文件裏會看到id標示的做用。

3.尾部

<footer>標籤實現

<footer id="page_footer"> <h2>Footer</h2> </footer>

說明:位置是頁面或者區塊的尾部,用法和<header>基本同樣,也會包含其餘元素,這裏也指定了id.

4.導航

<nav>標籤實現

複製代碼
<nav> <ul> <li><a href="#">Home</a></li> <li><a href="#">One</a></li> <li><a href="#">Two</a></li> <li><a href="#">Three</a></li> </ul> </nav>
複製代碼

說明:導航的重要性對於一個網頁相當重要,快速方便的導航是留住訪客所必須的。

1)能夠被包含在<header>或<footer>或者其餘區塊中,一個頁面能夠有多個導航。

2)導航通常須要CSS來渲染,隨後將會看到CSS的渲染。

5.區塊和文章

<section>和<article>標籤實現

複製代碼
<section id="posts"> /*能夠包含多個< article>*/ <article class="post"> /*article的內容*/ </article> <article class="post"> /*article的內容*/ </article> </section>
複製代碼

<section>元素將頁面的內容合理歸類,合理佈局。

下面是<article>的通常內容

複製代碼
<article class="post"> <header> <h2>Article Header</h2> </header> <p>Without you?I'd be a soul without a purpose. </p> <footer> <h2>Article Footer</h2> </footer> </article>
複製代碼

能夠看到它能夠包含不少元素。

6.旁白和側邊欄

<aside>標籤實現旁白,側邊欄則由<section>實現。

<aside>是爲主內容添的附加信息,入引言,圖片等

<aside> <p>sth. in aside </p> </aside>

<aside>通常加在<article>中使用

複製代碼
<article class="post"> <header> <h2>Article Header</h2> </header> <aside> <p>sth. in aside </p> </aside> <p>Without you?I'd be a soul without a purpose. </p> <footer> <h2>Article Footer</h2> </footer> </article>
複製代碼

側邊欄,不是旁白!看作是右面的一個區域,包含連接,用<section>和<nav>實現便可。

複製代碼
<section id="sidebar"> <nav> <ul> <li><a href="2012/04">April 2012</a></li> <li><a href="2012/03">March 2012</a></li> <li><a href="2012/02">February 2012</a></li> <li><a href="2012/01">January 2012</a></li> </ul> </nav> </section>
複製代碼

到這裏,每種標籤的使用就是這樣了,下面是HTML5的完整代碼index.html文件

View Code
<!DOCTYPE html> <html lang="en-US"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <link rel="stylesheet" href="style.css" type="text/css"> <title>Layout TEST</title> </head>
<body> <h2>body</h2> <header id="page_header"> <h1>Header</h1> <nav> <ul> <li><a href="#">Home</a></li> <li><a href="#">One</a></li> <li><a href="#">Two</a></li> <li><a href="#">Three</a></li> </ul> </nav> </header> <section id="posts"> <h2>Section</h2> <article class="post"> <h2>article</h2> <header> <h2>Article Header</h2> </header> <aside> <h2>Article Aside</h2> </aside> <p>Without you?I'd be a soul without a purpose. </p> <footer> <h2>Article Footer</h2> </footer> </article> <article class="post"> <h2>article</h2> <header> <h2>Article Header</h2> </header> <aside> <h2>Article Aside</h2> </aside> <p>Without you?I'd be a soul without a purpose. </p> <footer> <h2>Article Footer</h2> </footer> </article> </section>
<section id="sidebar"> <h2>Section</h2> <header> <h2>Sidebar Header</h2> </header> <nav> <h3></h3> <ul> <li><a href="2012/04">April 2012</a></li> <li><a href="2012/03">March 2012</a></li> <li><a href="2012/02">February 2012</a></li> <li><a href="2012/01">January 2012</a></li> </ul> </nav> </section>
<footer id="page_footer"> <h2>Footer</h2> </footer>
</body> </html>

二.CSS3部分

對於CSS文件,最好可以根據HTML文件的樹結構,對應到相應的元素,有組織有層次的進行元素屬性的渲染。這樣既可以不遺漏元素,又便於查找修改。固然根據我的的習慣來定就好。

CSS3的屬性定義更加豐富,這裏再也不贅述,網上有CSS3參考手冊,用的時候查一查就好。更或者,連查都懶得查,還有專門的CSS3控件代碼生成工具和網站,例如http://css-tricks.com/examples/,豐富的控件效果示例能夠下載。還能夠搜一些相似的。

這裏直接貼出CSS3代碼 style.css文件

複製代碼
@charset "utf-8"; /* CSS Document */ body { /*整個頁面的屬性設定*/ background-color: #CCCCCC; /*背景色*/ font-family: Geneva, sans-serif; /*可用字體*/ margin: 10px auto; /*頁邊空白*/ max-width: 800px; border: solid; /*邊緣立體*/ border-color: #FFFFFF; /*邊緣顏色*/ }
h2 { /*設定整個body內的h2的共同屬性*/ text-align: center; /*文本居中*/ }
header { /*整個body頁面的header適用*/ background-color: #F47D31; color: #FFFFFF; text-align: center; }
article { /*整個body頁面的article適用*/ background-color: #eee; }
p { /*整個body頁面的p適用*/ color: #F36; }
nav,article,aside { /*共同屬性*/ margin: 10px; padding: 10px; display: block; }
header#page_header nav { /*header#page_header nav的屬性*/ list-style: none; margin: 0; padding: 0; }
header#page_header nav ul li { /*header#page_header nav ul li屬性*/ padding: 0; margin: 0 20px 0 0; display: inline; }
section#posts { /*#posts 的section屬性*/ display: block; float: left; width: 70%; height: auto; background-color: #F69; }
section#posts article footer { /*section#posts article footer屬性*/ background-color: #039; clear: both; height: 50px; display: block; color: #FFFFFF; text-align: center; padding: 15px; }
section#posts aside { /*section#posts aside屬性*/ background-color: #069; display: block; float: right; width: 35%; margin-left: 5%; font-size: 20px; line-height: 40px; }
section#sidebar { /*section#sidebar屬性*/ background-color: #eee; display: block; float: right; width: 25%; height: auto; background-color: #699; margin-right: 15px; }
footer#page_footer { /*footer#page_footer屬性*/ display: block; clear: both; width: 100%; margin-top: 15px; display: block; color: #FFFFFF; text-align: center; background-color: #06C; }
複製代碼
相關文章
相關標籤/搜索