html5新元素

來源:互聯網
上載者:User

標籤:home   display   cto   編寫   amp   ffffff   tricks   padding   list   

TML5的語義化標籤以及屬性,可以讓開發人員非常方便地實現清晰的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檔案;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;
}
 
相信無需多解釋,一看就能明白。
想要讓頁面的顯示更精美絢麗,CSS3好好看看吧。
一些HTML5+CSS3的超炫網站:

No.1 HTML5 Awesome

 

 

No.2 HTML5 Showcase

 

 

No.3 HTML5 Lab

 

 

No.4 HTML5 Gallery

 

 

No.5 HTML5Beauty

 

html5新元素

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.