close

前端工程師該怎麼選擇使用Div還是Span呢?兩者究竟有什麼區別呢?

前端工程師該怎麼選擇使用Div還是Span呢?兩者究竟有什麼區別呢?

 

在撰寫 HTML 網頁時,可以用 <div> 或 <span> 標籤包住多個圖文、表格等元素。這些被包起來的元素就被視為一個區塊。

<div> 和<span> 的用法很雷同,都可將 HTML 的內容分為不同的區域。不同的是被 <span> 標籤包起來的元素,會被瀏覽器視為一行;而被 <div> 包起來的元素,則被視為一個區塊。
<div> 或 <span> 的元素沒有特定的含意,前端工程師如果將其與 CSS 一同使用,則<div> 可針對較大的區塊內容定義其樣式;<span> 則是為行內部分內容或細節設定樣式。

目錄
1. 概述
2. Div 與 Span 標籤概述
  2-1. Div 標籤概述
  2-2. Span 標籤概述


Div 這個標籤可以解釋為區塊,目的是將內容分為不同的區塊 (block),而每一個 Div 區塊可以根據 CSS 中宣告的樣式而定義其外觀。用 DIV 標籤包起來 (格式大致上是這樣<div>...</div>) 的元素,會被瀏覽器會視為一塊物件。你可以用 div 將網頁內容的各元素 (圖、文、表格等等) 包起來,再針對各區塊,去做 CSS 的排板。Div 是一個區塊級容器 (block-level container),這代表在<div>與</div> 標籤後會換行。

如何將 CSS 樣式套用至 <div> 區塊?

通常要讓 <div> 區塊都會加個 「class 選擇器」 或是 「id 選擇器」 來套用 CSS 樣式,其語法格式會是 「 <div class="CSS 的 class 名稱">...</div> 」 或是 「 <div id="CSS 的 id 名稱">...</div> 」。「class 選擇器」 以及 「id 選擇器」 的說明,請見此兩篇: <CSS 的 ID 選擇器宣告法>、<CSS 的 Class 選擇器宣告法>
舉例來說,我們已經定義了以下的 CSS 樣式
 
.block-1 { 
  color: blue; 
  font-family:微軟正黑體; 
  font-size: 20pt; 
}
.block-2 { 
  color: red; 
  font-family:新細明體; 
  font-size: 16pt; 
}
.block-3 { 
  color: green; 
  font-family: 標楷體; 
  font-size: 18pt; 
}

要如何使用 <div> 來套用其 CSS 樣式,其 HTML 碼如下所示:
 
<body>
 <div class="block-1">這裡是網頁<h1>第一個區塊</h1>的內容</div>
 <div class="block-2">這裡是網頁<span class="block-3">第二</span>個
 <span class="block-1">區</span>塊的內容</div>
 <div class="block-3">這裡是網頁<h3>第三個區塊</h3>的內容</div>
</doby>

則結果如下所示(左邊為 HTML、右邊為顯示結果):

在以上的例子中,我們可以知道:

 

 

1. <div> 是一個獨立的區塊容器 (block-level container),所以會獨自占用一行。如以上的例子中,左邊的 HTML 碼沒有使用 <br> 來斷行,而是讓三個 <div> 藉由其區塊的特性而自動分行

 

2. 每個 DIV 包起來的區塊裡面都可以各自加入 <h1>、 <h3> 或 <span> 等標籤做規劃。如以上的例子中,第一個區塊 (<div class=".block-1">) 中就包含了 <h1> 標籤;第二個區塊 ( <div class=".block-2"> ) 中就包含了兩個 <span> 標籤、第三個區塊 (<div class=".block-3">) 中就包含了 <h3> 標籤

 

3. SPAN 包起來元素,有別於 DIV 區塊,被瀏覽器視為一行。如以上的例子中,第二個區塊 ( <div class=".block-2"> ) 中就包含了兩個 <span> 標籤,但都在同一行內

 

推薦閱讀:

前端工程師跟後端學的東西差很大!

教你為網站妝模作樣的CSS網頁設計課程

HTML5教學後要學什麼?當然是CSS語法,讓網頁更美觀!

是日救星!人工智慧語音辨識 APP 雅婷逐字稿,台灣國語也逃不過雅婷的掌心!

賣場人員救星!什麼都逃不過人工智慧機器的法眼!

學習Python課程,你的未來無限可能!

HTML5教學讓你讀電子書更加賞心悅目!

arrow
arrow
    創作者介紹
    創作者 Ezra.Yii5778 的頭像
    Ezra.Yii5778

    Java課程是為了今日.Python課程是為了將來

    Ezra.Yii5778 發表在 痞客邦 留言(0) 人氣()