搜尋

虛擬類別選擇器 ( 超連結 )

「超連結」虛擬類別選擇器主要是針對「a 元素」的進階選擇器,這種選擇器主要有 :link、:visited、:any-link、:target 四種,可以清楚設定「尚未點擊、點擊過或具有特殊指向性超連結」的樣式,這篇教學會介紹和「超連結」有關的虛擬類別選擇器。

CSS 教學 - 虛擬類別選擇器 ( 超連結 )

「超連結」虛擬類別選擇器

下方列出和「超連結」有關的虛擬類別選擇器 ( 支援度 All 表示主流瀏覽器都支援 ):

通常超連結類型的虛擬類別選擇器,還會搭配「:hover」或「:active」操作行為虛擬類別選擇器使用。

虛擬類別選擇器 說明 支援度
:link 沒有被點擊過超連結。 All
:visited 被點擊過的超連結。 All
:any-link 超連結。 IE 不支援
:target 錨點目標元素。 All

:link

:link」表示「沒有被點擊過超連結」的元素,嚴格來說只會選擇「具有 href 屬性並且沒有被點擊過的 a 元素」,下方的範例執行後,只有具有 href 屬性的 a 元素才會變成綠色,沒有 href 屬性的 a 元素則是紅色,而其他元素就算具有 href 元素仍然不會被 :link 影響。

注意,如果點擊過連結,瀏覽器就會自動套用已經點擊過的樣式。

線上展示:https://codepen.io/oxxo/pen/NWVNVGj

<!-- HTML 程式碼 -->
<a href="https://www.oxxostudio.tw">oxxo.studio</a>
<br/>
<a href="https://steam.oxxostudio.tw">STEAM 教育學習網</a>
<br/>
<a>我沒有 href</a>
<br/>
<span href="#">使用 span 完全沒作用</span>

<!-- CSS 程式碼 -->
<style>
  a {color: red;}       /* 所有 a 都是紅色 */
  :link {color: green;} /* 具有 href 且沒有被點擊過的 a 是綠色 */
</style>

CSS 教學 - 虛擬類別選擇器 (超連結 ) - a:link

因為直接使用「a 元素」選擇器等同時使用「a:link」和「a:visited」,且還沒有「只能點擊一次」限制,所以越來越多人會使用下方的寫法,也可以產生同樣的效果。

線上展示:https://codepen.io/oxxo/pen/abrNrZX

<!-- HTML 程式碼 -->
<a href="https://www.oxxostudio.tw">oxxo.studio</a>
<br/>
<a href="https://steam.oxxostudio.tw">STEAM 教育學習網</a>
<br/>
<a>我沒有 href</a>
<br/>
<span href="#">使用 span 完全沒作用</span>

<!-- CSS 程式碼 -->
<style>
  a {color: red;}           /* 所有 a 都是紅色 */
  a[href] {color: green;}   /* 具有 href 的 a 都是綠色 */
</style>

CSS 教學 - 虛擬類別選擇器 (超連結 ) - a:link

:visited

:visited」表示「被點擊過的超連結」,嚴格來說只會選擇「具有 href 屬性並且被點擊過的 a 元素」,如果只是使用「a 元素」作為選擇器,其表現的方式等於同時使用「a:link」和「a:visited」,下方的範例執行後,兩組超連結的表現行為會一模一樣 ( 沒有點過是綠色,點過之後還是綠色 )。

線上展示:https://codepen.io/oxxo/pen/qBGZGme

<!-- HTML 程式碼 -->
<div class="g1">
  <a href="https://www.oxxostudio.tw">oxxo.studio</a>
  <br/>
  <a href="https://steam.oxxostudio.tw">STEAM 教育學習網</a>
</div>
<div class="g2">
  <a href="https://www.oxxostudio.tw">oxxo.studio</a>
  <br/>
  <a href="https://steam.oxxostudio.tw">STEAM 教育學習網</a>
</div>

<!-- CSS 程式碼 -->
<style>
  .g1 a {color: green;}           /* 所有超連結都是綠色,不論有沒有點過 */

  .g2 a {color: green;}           /* 所有超連結都是綠色 */
  .g2 a:visited {color: red;}     /* 點擊過的超連結都是紅色 */
</style>

CSS 教學 - 虛擬類別選擇器 (超連結 ) - a:visited

因為受限於瀏覽器隱私設定,:visited 具有下列相關限制:

  • 只能使用部分屬性colorbackground-colorborder-colorborder-bottom-colorborder-left-colorborder-right-colorborder-top-colorcolumn-rule-coloroutline-colortext-decoration-colortext-emphasis-color
  • 只支援部分 SVG 屬性fillstroke
  • 不能使用半透明:只能完全透明或完全不透明。
  • 只能「覆寫」樣式屬性:需要先具有該樣式屬性,才能覆寫和套用該樣式屬性。
  • 無法使用 JavaScript 取得目前 :visited 的設定值

舉例來說,上方這組超連結因為 a 沒有設定 background-color,所以就算 a:visited 有設定,也不會變色,但下方的超連結因為 a 裡面有 background-colora:visited 就能用覆寫的方式變色,但因為不支援 font-size 屬性,所以字體會保持原本的 20px。

線上展示:https://codepen.io/oxxo/pen/abrNrVr

<!-- HTML 程式碼 -->
<div class="g1">
  <a href="https://www.oxxostudio.tw">oxxo.studio</a>
  <br/>
  <a href="https://steam.oxxostudio.tw">STEAM 教育學習網</a>
</div>
<div class="g2">
  <a href="https://www.oxxostudio.tw">oxxo.studio</a>
  <br/>
  <a href="https://steam.oxxostudio.tw">STEAM 教育學習網</a>
</div>

<!-- CSS 程式碼 -->
<style>
  .g1 a {color: green;}                       /* 所有超連結都是綠色 */
  .g1 a:visited {background-color: orange;}   /* 點擊過的超連結會有橘色背景 ( 不會執行 ) */

  .g2 a {
    font-size:20px;            /* 所有超連結文字大小都是 20px */
    color: green;              /* 所有超連結都是綠色 */
    background-color: white;   /* 所有超連結背景都是白色 */
  }           
  .g2 a:visited {
    font-size:100px;           /* 所有超連結文字大小都是 100px */
    color: red;                /* 所有超連結都是紅色 */
    background-color: orange;  /* 所有超連結背景都是橘色 */
  }   
</style>

CSS 教學 - 虛擬類別選擇器 (超連結 ) - a:visited 使用限制

:any-link

:any-link」表示「超連結元素」,換句話說只會選擇「具有 href 屬性的 a 元素」,其表現的方式等於使用「a 元素」作為選擇器,也等於同時使用「a:link」和「a:visited,下方的範例執行後,超連結不論有沒有點擊過都會是綠色,但不具有 href 屬性的 a 元素則是紅色,具有 href 屬性的 span 元素則是黑色。

線上展示:https://codepen.io/oxxo/pen/yLWOWER

<!-- HTML 程式碼 -->
<a href="https://www.oxxostudio.tw">oxxo.studio</a>
<br/>
<a href="https://steam.oxxostudio.tw">STEAM 教育學習網</a>
<br/>
<a>我沒有 href</a>
<br/>
<span href="#">使用 span 完全沒作用</span>

<!-- CSS 程式碼 -->
<style>
  a {color: red;}           /* 所有的 a 都是紅色 */
  :any-link {color: green;} /* 超連結元素為綠色 */
</style>

CSS 教學 - 虛擬類別選擇器 (超連結 ) - a:any-link

:target

:target」表示「錨點目標元素」,意思是當「具有 ID 錨點的網址所對應的 ID 元素」,舉例來說,如果網址有方有「#apple」,則 :target 選擇器就會自動選取 ID 為 apple 的元素,將該元素套用對應的樣式。

線上展示 ( 自行更換 apple 測試 ):https://output.jsbin.com/yaguwutazi/2#apple

<!-- HTML 程式碼 -->
<h2 id="oxxo">oxxo</h2>
<h2 id="apple">apple</h2>
<h2 id="banana">banana</h2>
<h2 id="orange">orange</h2>

<!-- CSS 程式碼 -->
<style>
  :target {color: red;}
</style>

CSS 教學 - 虛擬類別選擇器 (超連結 ) - :target

小結

「超連結」的虛擬類別選擇器主要都是針對超連結使用,也常搭配「:hover」或「:active」操作行為虛擬類別選擇器,讓超連結更具有互動和反饋,是使用頻率相當高的選擇器喔。

意見回饋

如果有任何建議或問題,可傳送「意見表單」給我,謝謝~

CSS 教學

基本介紹

認識 CSS 開始使用 CSS CSS 語法規則 CSS 命名原則 CSS 常用樣式屬性

CSS 選擇器

認識 CSS 選擇器 優先順序 ( 權重 ) 樣式繼承與聯集 使用巢狀結構語法 元素選擇器 ID 和 Class 選擇器 屬性選擇器 文件結構選擇器 虛擬類別選擇器 ( 結構 ) 虛擬類別選擇器 ( 類型 ) 虛擬類別選擇器 ( 輸入 ) 虛擬類別選擇器 ( 行為 ) 虛擬類別選擇器 ( 超連結 ) 虛擬類別選擇器 ( 邏輯 ) 虛擬類別選擇器 ( 其他 ) 虛擬元素選擇器 群組與組合選擇器

數值與單位

關鍵字與文字數值 長度與角度單位 位置名稱與時間單位

規則與定義

變數 ( Variables ) 媒體查詢 ( @media ) 容器查詢 ( @container ) 自訂屬性值 ( @property ) 匯入樣式 ( @import ) 分層優先順序 ( @layer )

函式類型

數學計算 文字與清單計數 形狀與線段 路徑 ( path ) 生成內容與引號

顏色與濾鏡

顏色單位 色彩模型 漸層色 影像濾鏡 ( filter ) 背景濾鏡 ( backdrop-filter ) 混合模式 ( mix-blend-mode )

文字與段落

設定字型 ( font-family ) 使用外部字型 定義字型 ( @font-face ) 文字尺寸 文字樣式 ( 常用 ) 文字樣式 ( 其他實用 ) 文字樣式 ( 特殊用途 ) 文字換行 文字空白與 Tab 大小 文字行高與縮排 文字水平與垂直對齊 文字書寫方向 文字自動分欄

元素容器

容器顯示類型 ( display ) 元素 display 對照表 盒子模型 ( Box Model ) 寬度與高度 內邊距 ( padding ) 外邊界 ( margin ) 邊框 ( border ) 邊框圓角 ( border-radius ) 影像邊框 ( border-image ) 輪廓 ( outline ) 內容溢出與裁切 ( overflow ) 內容範圍 ( contain ) 可見性與透明度

背景與陰影

背景顏色 背景圖 ( 定位、尺寸 ) 背景圖 ( 固定、重複 ) 背景圖 ( 多重背景、混合 ) 背景縮寫 ( background ) 容器陰影 ( box-shadow )

清單與表格

清單樣式 清單計數器 定義計數規則 表格基本樣式 表格邊框樣式 表格內容寬度與對齊

基本排版與定位

元素排版方式 浮動 ( float ) 浮動形狀 定位 ( position )

Flexbox 彈性排版

Flexbox 彈性盒子 Flexbox 對齊方式 Flexbox 彈性伸縮

Grid 網格排版

Grid 網格容器與格線 Grid 網格空間與命名 Grid 網格流向與間距 Grid 排列網格項目 Grid 項目對齊與順序

轉場與動畫

轉場 ( transition ) 轉場觸發事件 動畫 ( animation ) 自訂動畫路徑 ( offset ) 動畫觸發事件 多重動畫的權重與順序

變形、裁切與遮罩

裁切路徑 ( clip-path ) 影像遮罩 ( mask ) 物件填滿方式與定位 轉換函式 ( transform ) 平移、旋轉與縮放 3D 轉換與透視 3D 正多面體

視窗與使用者行為

捲軸樣式 ( scrollbar ) 滑鼠游標圖示 ( cursor ) 滑鼠事件 ( pointer-events ) 使用者選取 ( user-select ) 捲動行為 ( scroll、overscroll )

範例效果

CSS 圓餅圖 CSS 跑馬燈 Google 載入動畫 漸層色的轉場與動畫 電子時鐘數字 不規則形狀動畫