婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 詳解HTML5中div和section以及article的區別

詳解HTML5中div和section以及article的區別

熱門標簽:外呼線穩定線路 地圖標注位置能賺錢嗎 邢臺縣地圖標注app pageadm實現地圖標注 申請400電話流程簡介 外呼系統電話怎么投訴 阜陽企業外呼系統 南通數據外呼系統推廣 呼和浩特外呼電銷系統排名

剛剛開始接觸 HTML5 時,對它的標簽很不適應,甚至一度有點反感。尤其是對 div、section、article 這幾個標簽,實在弄不清楚應該使用在什么場合下。
div

HTML Spec:

    The div element has no special meaning at all.

這個標簽是我們見得最多、用得最多的一個標簽。本身沒有任何語義,用作布局以及樣式化或腳本的鉤子(hook)。
section

HTML Spec: “The section element represents a generic section of a document or application. A section, in this context, is a thematic grouping of content, typically with a heading.”

與 div 的無語義相對,簡單地說 section 就是帶有語義的 div 了,但是千萬不要覺得真得這么簡單。section 表示一段專題性的內容,一般會帶有標題。看到這里,我們也許會想到,那么一篇博客文章,或者一條單獨的評論豈不是正好可以用 section 嗎?接著看:

    Authors are encouraged to use the article element instead of the section element when it would make sense to syndicate the contents of the elemen.

當元素內容聚合起來更加言之有物時,應該使用 article 來替換 section 。

那么,section 應該什么時候用呢?再接著看:

    Examples of sections would be chapters, the various tabbed pages in a tabbed dialog box, or the numbered sections of a thesis. A Web site’s home page could be split into sections for an introduction, news items, and contact information.

section 應用的典型場景有文章的章節、標簽對話框中的標簽頁、或者論文中有編號的部分。一個網站的主頁可以分成簡介、新聞和聯系信息等幾部分。其實我對這里傳達信息很感興趣,因為感覺 section 和下面要介紹的 artilce 更加適用于模塊化應用,這個話題以后會出篇專門的文章來討論,這里暫時略過。

要注意,W3C 還警告說:

    The section element is not a generic container element. When an element is needed for styling purposes or as a convenience for scripting, authors are encouraged to use the div element instead. A general rule is that the section element is appropriate only if the element’s contents would be listed explicitly in the document’s outline.”

section 不僅僅是一個普通的容器標簽。當一個標簽只是為了樣式化或者方便腳本使用時,應該使用 div 。一般來說,當元素內容明確地出現在文檔大綱中時,section 就是適用的。

XML/HTML Code復制內容到剪貼板
  1. <article>     
  2.     <hgroup> <h1>Apples</h1> <h2>Tasty, delicious fruit!</h2> </hgroup>  
  3.     <p>The apple is the pomaceous fruit of the apple tree.</p>    
  4.     <section>    
  5.         <h1>Red Delicious</h1>    
  6.         <p>These bright red apples are the most common found in many supermarkets.</p>    
  7.     </section>    
  8.     <section>    
  9.         <h1>Granny Smith</h1>  
  10.         <p>These juicy, green apples make a great filling for apple pies.</p>    
  11.     </section>    
  12. </article>    

article

HTML Spec:

    The article element represents a self-contained composition in a document, page, application, or site and that is, in principle, independently distributable or reusable, e.g. in syndication.

article 是一個特殊的 section 標簽,它比 section 具有更明確的語義, 它代表一個獨立的、完整的相關內容塊。一般來說, article 會有標題部分(通常包含在 header 內),有時也會 包含 footer 。雖然 section 也是帶有主題性的一塊內容,但是無論從結構上還是內容上來說,article 本身就是獨立的、完整的。

HTML Spec 中接著又列舉了一些 article 適用的場景。

    This could be a forum post, a magazine or newspaper article, a blog entry, a user-submitted comment, an interactive widget or gadget, or any other independent item of content.

當 article 內嵌 article 時,原則上來說,內部的 article 的內容是和外層的 article 內容是相關的。例如,一篇博客文章中,包含用戶提交的評論的 article 就應該潛逃在包含博客文章 article 之中。

問題是怎么才算“完整的獨立內容”?有個最簡單的判斷方法是看這段內容在 RSS feed 中是不是完整的。看這段內容脫離了所在的語境,是否還是完整的、獨立的。

例子:

XML/HTML Code復制內容到剪貼板
  1. <article>     
  2.     <header>    
  3.         <h1>The Very First Rule of Life</h1>    
  4.         <p><time pubdate datetime="2009-10-09T14:28-08:00"></time></p>  
  5.     </header>    
  6.     <p>If there's a microphone anywhere near you, assume it's hot and sending whatever you're saying to the world. Seriously.</p>    
  7.     <p>...</p>    
  8.     <footer>  
  9.         <a href="?comments=1">Show comments...</a>  
  10.     </footer>    
  11. </article>  
  12.   
  13. <article>     
  14.     <header>    
  15.         <h1>The Very First Rule of Life</h1>  
  16.         <p><time pubdate datetime="2009-10-09T14:28-08:00"></time></p>    
  17.     </header>  
  18.     <p>If there's a microphone anywhere near you, assume it's hot and sending whatever you're saying to the world. Seriously.</p>    
  19.     <p>...</p>    
  20.     <section>  
  21.         <h1>Comments</h1>    
  22.         <article>  
  23.             <footer>  
  24.                 <p>Posted by: George Washington</p>  
  25.                 <p><time pubdate datetime="2009-10-10T19:10-08:00"></time></p>    
  26.             </footer>  
  27.             <p>Yeah! Especially when talking about your lobbyist friends!</p>    
  28.         </article>    
  29.           <article>  
  30.             <footer>    
  31.                 <p>Posted by: George Hammond</p>  
  32.                 <p><time pubdate datetime="2009-10-10T19:15-08:00"></time></p>  
  33.             </footer>  
  34.             <p>Hey, you have the same first name as me.</p>  
  35.         </article>    
  36.     </section>    
  37. </article>    

總結

div section article ,語義是從無到有,逐漸增強的。div 無任何語義,僅僅用作樣式化或者腳本化的鉤子(hook),對于一段主題性的內容,則就適用 section,而假如這段內容可以脫離上下文,作為完整的獨立存在的一段內容,則就適用 article。原則上來說,能使用 article 的時候,也是可以使用 section 的,但是實際上,假如使用 article 更合適,那么就不要使用 section 。nav 和 aside 的使用也是如此,這兩個標簽也是特殊的 section,在使用 nav 和 aside 更合適的情況下,也不要使用 section 了。

對于 div 和 section、 article 以及其他標簽的區分比較簡單。對于 section 和 article 的區分乍看比較難,其實重點就是看看這段內容脫離了整體是不是還能作為一個完整的、獨立的內容而存在,這里面的重點又在完整身上。因為其實說起來 section 包含的內容也能算作獨立的一塊,但是它只能算是組成整體的一部分,article 才是一個完整的整體。

因為其實有些時候每個人都有自己的看法,所以難免有難于決斷的時候,怎么辦?

在 HTML5 設計原理 中,有一條是專門用來解決類似情況的:

最終用戶優先(Priority of Constituencies)

“In case of conflict, consider users over authors over implementors over specifiers over theoretical purity.” 一旦遇到沖突,最終用戶優先,其次是作者,其次是實現者,其次標準制定者,最后才是理論上的完滿。

推薦各位多讀幾遍 HTML5 設計原理,這才是紛繁世界背后的最終奧義。

標簽:辛集 內蒙古 楊凌 鶴崗 德州 蚌埠 黃山 撫順

巨人網絡通訊聲明:本文標題《詳解HTML5中div和section以及article的區別》,本文關鍵詞  詳解,HTML5,中,div,和,section,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解HTML5中div和section以及article的區別》相關的同類信息!
  • 本頁收集關于詳解HTML5中div和section以及article的區別的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 娄烦县| 二连浩特市| 达日县| 桐乡市| 石林| 随州市| 石阡县| 崇仁县| 安康市| 静宁县| 庆安县| 庆城县| 安远县| 潍坊市| 丁青县| 宁南县| 贵定县| 文山县| 安西县| 伊宁市| 集贤县| 宾阳县| 鲜城| 武功县| 泰顺县| 谢通门县| 肥西县| 巴青县| 普宁市| 皮山县| 佛教| 靖远县| 临武县| 突泉县| 沛县| 怀仁县| 丹巴县| 德令哈市| 中山市| 沅陵县| 通辽市|