iT邦幫忙

2021 iThome 鐵人賽

DAY 5
0
Modern Web

30天學會HTML+CSS,製作精美網站系列 第 5

認識網頁元素 HTML、CSS

看完了前幾天製作網頁,所需要的素材、使用編輯器及製作網站的流程後後,今天要來介紹HTML、CSS的基本結構,跨出製作網站的第一步了

HTML

HTML是什麼?

HTML是Hypertext Markup Language的縮寫,中文全名為「超文字標示語言」。HTML是告訴瀏覽器顯示什麼內容,像是標題、內容、表格、表單、圖片、文字、連結等。

HTML組成

https://ithelp.ithome.com.tw/upload/images/20210920/20112053Na2oxbRZ9w.png
每個標籤都會有開始與結束,在標籤中間可以放置自己要呈現的內容,可利用屬性定義的名稱給予樣式。每個標籤也會對應不同的屬性及值。
但需要注意的是每個頁面,id名稱是唯一值,不可以重複,就像身分證號碼一樣,一個號碼對應一個人的身份。class可以重複的被使用。且id與class的名稱大小寫是不同的,不能互相使用。EX:header、Header這兩個代表不一樣的class名稱。

HTML架構

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title>My test page</title>
  </head>
  <body>
    <img src="images/firefox-icon.png" alt="My test image">
  </body>
</html>

<!doctype html>

DOCTYPE 即是Document type(簡稱為DTDs),中文是「檔案類型」。說明網頁是用HTML哪個版本,像是HTML 4.01、XHTML 1.0、XHTML 1.1、HTML 5等版本。HTML5為網頁的最新版本,幾乎所有瀏覽器、手機都已經有支援。

<html></html>

識別是一個html文件

<head>

顯示網頁的資訊,包含標題、頁面說明、外部連結等。但不會顯示在瀏覽器畫面中。

<meta>

  • <meta charter=UTF-8>
    meta charter是用來指定網頁是什麼編碼。大多數的網頁編碼為「UTF-8」,如果網頁沒有指定正確的編碼時,文字會變成亂碼。
  • <meta name="description" content="....">
    description是用來描述你的網頁內容,只有在搜尋結果中,才能看到文字
    以apple官網為例,他在meta的描述裡面所寫的文字,會顯示在搜尋的描述上
    https://ithelp.ithome.com.tw/upload/images/20210920/20112053cd5YoTDNGb.png
    https://ithelp.ithome.com.tw/upload/images/20210920/20112053PMQMQfOqzy.png
  • <meta name="keywords" content="....">
    keywords是用來描述你的網頁內容有哪些關鍵字詞
  • <meta name="viewport" content="width=device-width, initial-scale=1.0">
    viewport是用來描述行動版網頁的 viewport 資訊

<title>

設定網頁標題,會顯示在瀏覽器的標籤上、加入我的最愛的標題、網頁搜尋結果

<body>

放置網頁在瀏覽器上要呈現的內容

在html裡面標籤沒有大小寫區別,但有的版本必須要小寫,因此建議統一以小寫為主。

註解 <!-- 和 -->

單行與多行註解都是使用<!-- 和 -→

<!--
	多行註解
	多行註解
	多行註解
-->
<!--單行註解-->

CSS

CSS是什麼?

CSS是Cascading style Sheets的縮寫,中文全名為「層疊樣式表單」。是用來美化HTML外觀的語言。像是文字顏色、大小、位置、邊框等。

如何在HTML中使用CSS

行內樣式 Inline Styles

直接在HTML Tag上寫style樣式,

<p style="color:#f00;font-size:18px;">我是內容</p>

內嵌樣式 Embeded Styles

在HTML 的標籤裡面使用style

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .text{
      color:#f00;
      font-size:18px;
    }
  </style>
</head>
<body>
  <p class="text">我是內容</p>
</body>

外部樣式 External Styesheets

在HTML 的<head>標籤裡用link方式引入CSS檔案

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <link rel="stylesheet" href="css/style.css">
</head>

引入方式有三種方法,行內樣式及嵌入樣式不易管理,且行內優先順序也會比較高,想部分調整可以使用此方法.但建議使用外部樣式方法,方便管理及維護

CSS組成

CSS是由選擇器(selector)、屬性(property)和值(value)組成
https://ithelp.ithome.com.tw/upload/images/20210920/20112053R4EshM2VYs.png

  • 選擇器:設定要改變哪一個元素外觀
  • 屬性:要改變什麼
  • 值 :如何改變
    以範例來說,要改變「.text這個class名稱」的外觀,要改變他的「顏色」,要改成「紅色」
    要設定多個選取器時,要用逗號(,)隔開;屬性與值之間用冒號(:)隔開;同時設定多個屬性與值時,要用分號(;)隔開,最後用大括號{ }括起來。

這邊要注意的是,設定選取器樣式時,建議給他們一個class或id名稱,不要直接設定html標籤,因為在HTML裡面使用到所設定的標籤,樣式就直接被套用,修改也會變得複雜。

CSS Reset 與 CSS normalize

為什麼會有CSS Reset及CSS normalize呢?

因多數瀏覽器使用的 HTML都會有自己的預設樣式,導致在每個瀏覽器上看都會有一點差異。所以為了讓每個瀏覽器樣式統一,才會有Reset及normalize的需求。

CSS Reset 與 CSS normalize該到底該用哪一個呢?

  • CSS Reset

    • 將瀏覽器默認樣式完全清空
    • 沒有彈性,需要什麼樣式要在自己做設定
    • 常見的CSS Reset:Eric Meyer Reset CSSHTML5 Reset Stylesheet
  • CSS normalize

    • 只會刪除瀏覽器的不一致,保留瀏覽器默認樣式
    • code會有大量註解,讓你知道每個樣式處理什麼問題
    • normalize.css 被使用在Bootstrap、Tailwind、Foundation等framework
      不論用哪一套都有人使用,針對你需求去做選擇。

前綴詞使用

撰寫CSS時,都會遇到不同瀏覽器之間的相容性問題,為了確保每個瀏覽器都支援所寫的CSS ,必須依照不同的瀏覽器加上專屬於它們的前綴,以確保CSS可以被正常執行。

  • webkit-:chrome、Safari
  • moz-:Firefox
  • -o- :Opera
  • -ms-: Internet Explorer、Microsoft Edge

不確定CSS支援程度可以到 Can I sue 查詢

結論

想像一個網頁就像一間房子,HTML就像是未裝修的房子,然後CSS是鋪上磁磚、油漆、將傢俱擺放到適合的位置並裝飾美美的,讓整體看起來舒適。
以上是HTML及CSS的介紹,相信你對HTML及CSS有基本的認識了


上一篇
改造你的VSCode,大幅提升你的Coding效率
下一篇
語意標籤-30天學會HTML+CSS,製作精美網站
系列文
30天學會HTML+CSS,製作精美網站30
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

尚未有邦友留言

立即登入留言