HTML5新元素
HTML新元素
HTML5的語(yǔ)義化標(biāo)簽以及屬性,可以讓開發(fā)者非常方便地實(shí)現(xiàn)清晰的web頁(yè)面布局,加上CSS3的效果渲染,快速建立豐富靈活的web頁(yè)面顯得非常簡(jiǎn)單。
本次學(xué)習(xí)HTML5的新標(biāo)簽元素有:
<header>定義頁(yè)面或區(qū)段的頭部;
<footer>定義頁(yè)面或區(qū)段的尾部;
<nav>定義頁(yè)面或區(qū)段的導(dǎo)航區(qū)域;
<section>頁(yè)面的邏輯區(qū)域或內(nèi)容組合;
<article>定義正文或一篇完整的內(nèi)容;
<aside>定義補(bǔ)充或相關(guān)內(nèi)容;
學(xué)習(xí)這些標(biāo)簽最好的方法當(dāng)然就是試著使用它們。雖然現(xiàn)在有很多現(xiàn)成的網(wǎng)頁(yè)布局的模板可以方便的拿來(lái)用,但是對(duì)于初學(xué)者來(lái)說(shuō),自己實(shí)現(xiàn)簡(jiǎn)單的頁(yè)面布局絕對(duì)是有必要的。這里通過(guò)一個(gè)簡(jiǎn)單的頁(yè)面布局的例子,來(lái)展示上述標(biāo)簽的使用方法。
示例:模仿博客首頁(yè)布局
實(shí)現(xiàn)如圖2-1的網(wǎng)頁(yè)結(jié)構(gòu),這是一個(gè)非常典型的博客頁(yè)面:頭部、尾部、水平導(dǎo)航欄、側(cè)邊欄導(dǎo)航以及內(nèi)容。
圖2-1
在圖2-1中已經(jīng)看到,相應(yīng)標(biāo)簽實(shí)現(xiàn)的區(qū)域用名稱標(biāo)注了出來(lái),比如頭部Header
在編寫頁(yè)面前,有必要說(shuō)一下:頁(yè)面元素由HTML5實(shí)現(xiàn),而元素的顯示效果是CSS3渲染的,CSS3的代碼可以和HTML5的代碼放在同一個(gè)文件,也可以是獨(dú)立的文件,只要在HTML5文件里引用即可。建議最好各自是獨(dú)立的文件,這樣的好處有:
1)符合單一職責(zé)原則:HTML5頁(yè)面就負(fù)責(zé)管理元素,而CSS3文件只負(fù)責(zé)對(duì)相應(yīng)HTML5文件顯示效果的渲染,相互獨(dú)立,互不相交。
2)降低頁(yè)面的復(fù)雜度,便于維護(hù):試想,當(dāng)頁(yè)面的元素?cái)?shù)量增到很多的時(shí)候,同時(shí)在一個(gè)頁(yè)面里管理元素和元素的顯示屬性,可讀性是該有多差,后期的維護(hù)會(huì)很蛋疼。
3)加快瀏覽器的加載速度:第2)點(diǎn)的另外一個(gè)好處,簡(jiǎn)單的頁(yè)面自然加載更快。
當(dāng)然,如果就是習(xí)慣HTML5+CSS3放在一個(gè)文件里,也未嘗不可,這里也只是建議。
下面來(lái)具體實(shí)現(xiàn)圖2-1。
1.HTML5的文檔聲明
新建index.html文件,如果用的網(wǎng)頁(yè)編寫工具已經(jīng)支持HTML5文件類型,那么,應(yīng)該生成如下的HTML5模板:
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>Layout TEST</title> </head> <body> </body> </html>
如果網(wǎng)頁(yè)編寫工具暫時(shí)不支持HTML5也沒(méi)關(guān)系,自己寫這幾行代碼也很簡(jiǎn)單。
說(shuō)明:第一行:<!DOCTYPE html>是HTML5對(duì)文檔類型的簡(jiǎn)化,化繁為簡(jiǎn);(文檔類型的作用:驗(yàn)證器依據(jù)它來(lái)判斷該采用何種規(guī)則去驗(yàn)證代碼;強(qiáng)制瀏覽器以標(biāo)準(zhǔn)模式渲染頁(yè)面)
2.頭部
<header>標(biāo)簽實(shí)現(xiàn)
<header id="page_header">
??? <h1>Header</h1>
</header>
?
說(shuō)明:1)header不能喝h1,h2,h3這些標(biāo)題混為一談。<header>可以包含從公司logo到搜索框在內(nèi)的各式各樣的內(nèi)容。例子中只含有標(biāo)題。
2)同一個(gè)頁(yè)面可以包含多個(gè)<header>元素。每個(gè)獨(dú)立的區(qū)塊或文章都可以含有自己的<header>.所以示例中為<header>添加唯一標(biāo)示id屬性,便于CSS3中靈活的渲染。在CSS文件里會(huì)看到id標(biāo)示的作用。
3.尾部
<footer>標(biāo)簽實(shí)現(xiàn)
<footer id="page_footer"> <h2>Footer</h2> </footer>
說(shuō)明:位置是頁(yè)面或者區(qū)塊的尾部,用法和<header>基本一樣,也會(huì)包含其他元素,這里也指定了id.
4.導(dǎo)航
<nav>標(biāo)簽實(shí)現(xiàn)
<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>
?
說(shuō)明:導(dǎo)航的重要性對(duì)于一個(gè)網(wǎng)頁(yè)至關(guān)重要,快速方便的導(dǎo)航是留住訪客所必須的。
1)可以被包含在<header>或<footer>或者其他區(qū)塊中,一個(gè)頁(yè)面可以有多個(gè)導(dǎo)航。
2)導(dǎo)航一般需要CSS來(lái)渲染,隨后將會(huì)看到CSS的渲染。
5.區(qū)塊和文章
<section>和<article>標(biāo)簽實(shí)現(xiàn)
<section id="posts"> /*可以包含多個(gè)< article>*/ <article> /*article的內(nèi)容*/ </article> <article> /*article的內(nèi)容*/ </article> </section>
?
<section>元素將頁(yè)面的內(nèi)容合理歸類,合理布局。
下面是<article>的一般內(nèi)容
<article> <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.旁白和側(cè)邊欄
<aside>標(biāo)簽實(shí)現(xiàn)旁白,側(cè)邊欄則由<section>實(shí)現(xiàn)。
<aside>是為主內(nèi)容添的附加信息,入引言,圖片等
<aside> <p>sth. in aside </p> </aside>
<aside>一般加在<article>中使用
<article> <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>
?
側(cè)邊欄,不是旁白!看做是右面的一個(gè)區(qū)域,包含鏈接,用<section>和<nav>實(shí)現(xiàn)即可。
<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>
到這里,每種標(biāo)簽的使用就是這樣了,下面是HTML5的完整代碼index.html文件
? View Code
<!DOCTYPE html> <html> <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> <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> <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>
接下來(lái)詳細(xì)介紹下新增的元素
<canvas> 新元素
<canvas> ? ? 標(biāo)簽定義圖形,比如圖表和其他圖像。該標(biāo)簽基于 JavaScript 的繪圖 API ?
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>php中文網(wǎng)(php.cn)</title> </head> <body> <canvas id="myCanvas">你的瀏覽器不支持 HTML5 canvas 標(biāo)簽。</canvas> <script> var c=document.getElementById('myCanvas'); var ctx=c.getContext('2d'); ctx.fillStyle='#FF0000'; ctx.fillRect(0,0,80,100); </script> </body> </html>
新多媒體元素
標(biāo)簽 ? ? ? ? ? ? ?描述
<audio> ? ? ? 定義音頻內(nèi)容 ? ?
<video> ? ? ? 定義視頻(video 或者 movie) ? ?
<source> ? ? 定義多媒體資源 <video> 和 <audio> ? ?
<embed> ? ? 定義嵌入的內(nèi)容,比如插件。 ? ?
<track> ? ? ? ?為諸如 <video> 和 <audio> 元素之類的媒介規(guī)定外部文本軌道。 ? ?
新表單元素
標(biāo)簽 ? ? ? ? ? ? ?描述
<datalist> ? ?定義選項(xiàng)列表。請(qǐng)與 input 元素配合使用該元素,來(lái)定義 input 可能的值。 ? ?
<keygen> ? ?規(guī)定用于表單的密鑰對(duì)生成器字段。 ? ?
<output> ? ?定義不同類型的輸出,比如腳本的輸出。 ? ?
新的語(yǔ)義和結(jié)構(gòu)元素
HTML5提供了新的元素來(lái)創(chuàng)建更好的頁(yè)面結(jié)構(gòu):
標(biāo)簽 ? ? ? ? ? ? 描述
<article> ? ?定義頁(yè)面獨(dú)立的內(nèi)容區(qū)域。 ? ?
<aside> ? ?定義頁(yè)面的側(cè)邊欄內(nèi)容。 ? ?
<bdi> ? ?允許您設(shè)置一段文本,使其脫離其父元素的文本方向設(shè)置。 ? ?
<command> ? ?定義命令按鈕,比如單選按鈕、復(fù)選框或按鈕 ? ?
<details> ? ?用于描述文檔或文檔某個(gè)部分的細(xì)節(jié) ? ?
<dialog> ? ?定義對(duì)話框,比如提示框 ? ?
<summary> ? ?標(biāo)簽包含 details 元素的標(biāo)題 ? ?
<figure> ? ?規(guī)定獨(dú)立的流內(nèi)容(圖像、圖表、照片、代碼等等)。 ? ?
<figcaption> ? ?定義 <figure> 元素的標(biāo)題 ? ?
<footer> ? ?定義 section 或 document 的頁(yè)腳。 ? ?
<header> ? ?定義了文檔的頭部區(qū)域 ? ?
<mark> ? ?定義帶有記號(hào)的文本。 ? ?
<meter> ? ?定義度量衡。僅用于已知最大和最小值的度量。 ? ?
<nav> ? ?定義導(dǎo)航鏈接的部分。 ? ?
<progress> ? ?定義任何類型的任務(wù)的進(jìn)度。 ? ?
<ruby> ? ?定義 ruby 注釋(中文注音或字符)。 ? ?
<rt> ? ?定義字符(中文注音或字符)的解釋或發(fā)音。 ? ?
<rp> ? ?在 ruby 注釋中使用,定義不支持 ruby 元素的瀏覽器所顯示的內(nèi)容。 ? ?
<section> ? ?定義文檔中的節(jié)(section、區(qū)段)。 ? ?
<time> ? ?定義日期或時(shí)間。 ? ?
<wbr> ? ?規(guī)定在文本中的何處適合添加換行符。 ? ?
已移除的元素
以下的 HTML 4.01 元素在HTML5中已經(jīng)被刪除:
<acronym>
<applet>
<basefont>
<big>
<center>
<dir>
<font>
<frame>
<frameset>
<noframes>
<strike>
<tt>