HTML5新元素LOGIN

HTML5新元素

HTML新元素

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

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

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

<footer>定義頁或區段的尾部;

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

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

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

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

學習這些標籤最好的方法當然就是試著使用它們。雖然現在有很多現成的網頁佈局的模板可以方便的拿來用,但是對於初學者來說,自己實現簡單的頁面佈局絕對是有必要的。這裡透過一個簡單的頁面佈局的例子,來展示上述標籤的使用方法。

範例:模仿部落格首頁佈局

實作如圖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的文檔聲明
新index.html文件,如果使用的網頁編寫工具已經支援HTML5文件類型,那麼,應該產生如下的HTML5模板:

<!DOCTYPE html>
  <html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
 <title>Layout TEST</title>
 </head>
  <body>
 </body>
 </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>
         /*article的内容*/
        </article>
        <article>
         /*article的内容*/
        </article>
</section>

 
<section>元素將頁面的內容合理歸類,合理佈局。
下面是<article>的一般內容

<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.旁白與側邊欄
<aside>標籤實作旁白,側邊欄則由<section>實作。
<aside>是為主內容添的附加信息,入引言,圖片等

<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>

 
側邊欄,不是旁白!看做是右面的一個區域,包含鏈接,用<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>
<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>

#接下來詳細介紹下新增的元素

<canvas> 新元素


##<canvas>     標籤定義圖形,例如圖表和其他圖像。此標籤基於JavaScript 的繪圖API  

<!DOCTYPE html> 
<html>
<head> 
<meta charset="utf-8"> 
<title>php中文网(php.cn)</title> 
</head> 
<body>
<canvas id="myCanvas">你的浏览器不支持 HTML5 canvas 标签。</canvas>
<script>
var c=document.getElementById('myCanvas');
var ctx=c.getContext('2d');
ctx.fillStyle='#FF0000';
ctx.fillRect(0,0,80,100);
</script>
</body>
</html>

新多媒體元素


#標籤             說明


<audio>       訂視訊內容或movie)    

<source>     定義多媒體資源<video> and<audio>    

<embed>     定義嵌入的內容,例如外掛程式。    

<track>        為諸如 <video> 和 <audio> 元素之類的媒介規定外部文字軌道。    

新表單元素


#標籤             說明




## <datalist>    定義選項清單。請與 input 元素搭配使用該元素,來定義 input 可能的值。    

<keygen>    規定表單的金鑰對產生器欄位。    

<output>    定義不同類型的輸出,例如腳本的輸出。

新的語意與結構元素

HTML5提供了新的元素來建立更好的頁面結構:

標籤            說明

######<article>    定義頁面獨立的內容區。    ######<aside>    定義頁面的側邊欄內容。    ######<bdi>    允許您設定一段文本,使其脫離其父元素的文字方向設定。 ######<command>    定義指令按鈕,例如單選按鈕、核取方塊或按鈕   ######<details>    用來描述文件或文件某部分的詳細資料內容  ##### #<dialog>    定義對話框,例如提示框   ######<summary>    標籤包含details 元素的標題   ######<figure>     元素的標題   ######<figure>    代碼等等)。    ######<figcaption>    定義 <figure> 元素的標題    #####<footer>    定義 section 或 document 的頁腳。    ######<header>    定義了文件的頭部區域    ######<mark>    定義記號的文字。    ######<meter>    定義度量衡。僅用於已知最大值和最小值的度量。    ###

<nav>    定義導覽連結的部分。    

<progress>    定義任何類型的任務的進度。    

<ruby>    定義 ruby​​ 註解(中文註音或字元)。    

<rt>    定義字元(中文註音或字元)的解釋或發音。    

<rp>    在 ruby​​ 註解中使用,定義不支援 ruby​​ 元素的瀏覽器所顯示的內容。    

<section>    定義文件中的節(section、區段)。    

<time>    訂定日期或時間。    

<wbr>    規定在文本中的何處適合新增換行符號。

已移除的元素

以下的HTML 4.01 元素在HTML5中已經刪除:

<acronym> ;

<applet>

<basefont>

<big>

<center>

<dir> ;

<font>

<frame>

<frameset>

<noframes>

<strike> ;

<tt>


#下一節
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>php中文网(php.cn)</title> </head> <body> <canvas id="myCanvas">你的浏览器不支持 HTML5 canvas 标签。</canvas> <script> var c=document.getElementById('myCanvas'); var ctx=c.getContext('2d'); ctx.fillStyle='#FF0000'; ctx.fillRect(0,0,80,100); </script> </body> </html>
章節課件