整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          HTML表單標簽詳解:如何用HTML標簽打造互動網頁?

          這里是云端源想IT,幫你輕松學IT”

          嗨~ 今天的你過得還好嗎?

          世界微塵里

          吾寧愛與憎


          - 2024.03.18 -

          在互聯網的世界中,表單是用戶與網站進行互動的重要橋梁。無論是注冊新賬號、提交反饋、還是在線購物,表單都扮演著至關重要的角色。在網頁中,我們需要跟用戶進行交互,收集用戶資料,此時就需要用到表單標簽。

          HTML提供了一系列的表單標簽,使得開發者能夠輕松地創建出功能豐富的表單。今天我們就來深入探討這些標簽,了解它們的作用以及如何使用它們來構建一個有效的用戶界面。



          一、表單的組成

          在HTML中,一個完整的表單通常由表單域、表單控件(表單元素)和提示信息三個部分構成。

          表單域

          • 表單域是一個包含表單元素的區域
          • 在HTML標簽中,<form>標簽用于定義表單域,以實現用戶信息的收集和傳遞
          • <form>會把它范圍內的表單元素信息提交給服務器


          表單控件

          這些是用戶與表單交云的各種元素,如<input>(用于創建不同類型的輸入字段)、<textarea>(用于多行文本輸入)、<button>(用于提交表單或執行其他操作)、<select>和<option>(用于創建下拉列表)等。



          提示信息

          這些信息通常通過<label>標簽提供,它為表單控件提供了描述性文本,有助于提高可訪問性。<label>標簽通常與<input>標簽一起使用,并且可以通過for屬性與<input>標簽的id屬性關聯起來。


          這三個部分共同構成了一個完整的HTML表單,使得用戶可以輸入數據,并通過點擊提交按鈕將這些數據發送到Web服務器進行處理。


          二、表單元素

          在表單域中可以定義各種表單元素,這些表單元素就是允許用戶在表單中輸入或者選擇的內容控件。下面就來介紹HTML中常用的表單元素。


          1、<form>標簽:基礎容器

          作用:定義一個表單區域,用戶可以在其中輸入數據進行提交。

          <form action="submit.php" method="post">

          其中action屬性指定了數據提交到的服務器端腳本地址,method屬性定義了數據提交的方式(通常為GET或POST)。


          2、<input>標簽:數據輸入

          <input>標簽是一個單標簽,用于收集用戶信息。允許用戶輸入文本、數字、密碼等。

          <input type="text" name="username" placeholder="請輸入用戶名">

          type屬性決定了輸入類型,name屬性定義了數據的鍵名,placeholder屬性提供了輸入框內的提示文本。


          <input>標簽的屬性

          下面舉個例子來說明:

          <!DOCTYPE html>
          <html>
          <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>
          </head>
          
          <body>
          <form>
          用戶名:<input type="text" value="請輸入用戶名"><br>
          密碼:<input type="password"><br>
          性別:男<input type="radio" name="sex" checked="checked"> 女<input type="radio" name="sex"><br>
          愛好:吃飯<input type="checkbox"> 睡覺<input type="checkbox"> 打豆豆<input type="checkbox"><br>
          <input type="submit" value="免費注冊">
          <input type="reset" value="重新填寫">
          <input type="button" value="獲取短信驗證碼"><br>
          上傳頭像:<input type="file">
          </form>
          </body>
          </html>


          3、<label>標簽:關聯說明

          它與輸入字段如文本框、單選按鈕、復選框等關聯起來,以改善網頁的可用性和可訪問性。<label>標簽有兩種常見的用法:


          1)包裹方式:

          在這種用法中,<label>標簽直接包裹住關聯的表單元素。例如:

          <label>用戶名:<input type="text" name="username"></label>

          這樣做的好處是用戶點擊標簽文本時,關聯的輸入字段會自動獲取焦點,從而提供更好的用戶體驗。



          2)使用for屬性關聯:

          在這種用法中,<label>標簽通過for屬性與目標表單元素建立關聯,for屬性的值應與目標元素的id屬性相匹配。例如:

          <label for="username">用戶名:</label><input type="text" id="username" name="username">

          這樣做的優勢是單擊標簽時,相關的表單元素會自動選中(獲取焦點),從而提高可用性和可訪問性。


          4、<select>和<option>標簽:下拉選擇

          在頁面中,如果有多個選項讓用戶選擇,并且想要節約頁面空間時,我們可以使用標簽控件定義下拉列表。


          注意點:

          • <select>中至少包含一對<option>
          • 在<option>中定義selected=“selected”時,當前項即為默認選中項
          <!DOCTYPE html>
          <html>
          <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>
          </head>
          <body>
          <form>
          籍貫:
          <select>
          <option>山東</option>
          <option>北京</option>
          <option>西安</option>
          <option selected="selected">火星</option>
          </select>
          </form>
          </body>
          </html>


          5、<textarea>標簽:多行文本輸入

          當用戶輸入內容較多的情況下,我們可以用表單元素標簽替代文本框標簽。

          • 允許用戶輸入多行文本。
          <textarea name="message" rows="5" cols="30">默認文本</textarea>

          rows和cols屬性分別定義了文本區域的行數和列數。


          代碼示例:

          <!DOCTYPE html>
          <html>
          <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>
          </head>
          <body>
          <form>
          今日反饋:
          <textarea>請在此輸入內容</textarea>
          </form>
          </body>
          </html>



          6、<button>標簽:按鈕控件

          創建一個可點擊的按鈕,通常用于提交或重置表單。它允許用戶放置文本或其他內聯元素(如<i>、<b>、<strong>、<br>、<img>等),這使得它比普通的<input type="button">具有更豐富的內容和更強的功能。

          <button type="submit">提交</button>

          type屬性為submit時表示這是一個提交按鈕。


          7、<fieldset>和<legend>標簽:分組和標題

          通常用于在HTML表單中對相關元素進行分組,并提供一個標題來描述這個組的內容。



          <fieldset>標簽:該標簽用于在表單中創建一組相關的表單控件。它可以將表單元素邏輯分組,并且通常在視覺上通過圍繞這些元素繪制一個邊框來區分不同的組。這種分組有助于提高表單的可讀性和易用性。

          <legend>標簽:它總是與<fieldset>標簽一起使用。<legend>標簽定義了<fieldset>元素的標題,這個標題通常會出現在瀏覽器渲染的字段集的邊框上方。<legend>標簽使得用戶更容易理解每個分組的目的和內容。

          代碼示例:

          <form>
          <fieldset>
          <legend>個人信息</legend>
          <label for="name">姓名:</label>
          <input type="text" id="name" name="name"><br><br>
          <label for="email">郵箱:</label>
          <input type="email" id="email" name="email"><br><br>
          </fieldset>
          <fieldset>
          <legend>興趣愛好</legend>
          <input type="checkbox" id="hobby1" name="hobby1" value="music">
          <label for="hobby1">音樂</label><br>
          <input type="checkbox" id="hobby2" name="hobby2" value="sports">
          <label for="hobby2">運動</label><br>
          <input type="checkbox" id="hobby3" name="hobby3" value="reading">
          <label for="hobby3">閱讀</label><br>
          </fieldset>
          <input type="submit" value="提交">
          </form>

          在這個示例中,我們使用了兩個<fieldset>元素來組織表單的不同部分。第一個<fieldset>包含姓名和郵箱字段,而第二個<fieldset>包含三個復選框,用于選擇用戶的興趣愛好。每個<fieldset>都有一個<legend>元素,用于提供標題。這樣,用戶在填寫表單時可以更清晰地了解每個部分的內容。

          想要快速入門前端開發嗎?推薦一個前端開發基礎課程,這個老師講的特別好,零基礎學習無壓力,知識點結合代碼,邊學邊練,可以免費試看試學,還有各種輔助工具和資料,非常適合新手!點這里前往學習哦!云端源想

          8、<datalist>標簽:預定義選項列表

          <datalist>標簽是HTML5中引入的一個新元素,它允許開發者為輸入字段提供預定義的選項列表。當用戶在輸入字段中輸入時,瀏覽器會顯示一個下拉菜單,其中包含與用戶輸入匹配的預定義選項。


          使用<datalist>標簽可以提供更好的用戶體驗,因為它可以幫助用戶選擇正確的選項,而不必手動輸入整個選項。此外,<datalist>還可以與<input>元素的list屬性結合使用,以將預定義的選項列表與特定的輸入字段關聯起來。



          下面是一個使用<datalist>標簽的代碼示例:

          <form>
          <label for="color">選擇你喜歡的顏色:</label>
          <input type="text" id="color" name="color" list="colorOptions">
          <datalist id="colorOptions">
          <option value="紅色">
          <option value="藍色">
          <option value="綠色">
          <option value="黃色">
          <option value="紫色">
          </datalist>
          <input type="submit" value="提交">
          </form>


          9、<output>標簽:計算結果輸出

          <output>標簽是HTML5中引入的一個新元素,它用于顯示計算結果或輸出。該標簽通常與JavaScript代碼結合使用,通過將計算結果賦值給<output>元素的value屬性來顯示結果。


          <output>標簽可以用于各種類型的計算和輸出,例如數學運算、字符串處理、數組操作等。它可以與<input>元素一起使用,以實時更新計算結果。



          下面是一個使用<output>標簽的示例:

          <form>
          <label for="num1">數字1:</label>
          <input type="number" id="num1" name="num1" oninput="calculate()"><br><br>
          <label for="num2">數字2:</label>
          <input type="number" id="num2" name="num2" oninput="calculate()"><br><br>
          <label for="result">結果:</label>
          <output id="result"></output>
          </form>
          
          <script>
          function calculate() {
          var num1 = parseInt(document.getElementById("num1").value);
          var num2 = parseInt(document.getElementById("num2").value);
          var result = num1 + num2;
          document.getElementById("result").value = result;
          }
          </script>


          10、<progress>標簽:任務進度展示

          <progress>標簽是HTML5中用于表示任務完成進度的一個新元素。它通過value屬性和max屬性來表示進度,其中value表示當前完成的值,而max定義任務的總量或最大值。

          示例:

          <!DOCTYPE html>
          <html>
          <head>
          <title>Progress Example</title>
          </head>
          <body>
          <h1>File Download</h1>
          <progress id="fileDownload" value="0" max="100"></progress>
          <br>
          <button onclick="startDownload()">Start Download</button>
          
          <script>
          function startDownload() {
          var progress = document.getElementById("fileDownload");
          for (var i = 0; i <= 100; i++) {
          setTimeout(function() {
          progress.value = i;
          }, i * 10);
          }
          }
          </script>
          </body>
          </html>

          在上面的示例中,我們創建了一個名為"fileDownload"的<progress>元素,并設置了初始值為0,最大值為100。我們還添加了一個按鈕,當用戶點擊該按鈕時,會觸發名為"startDownload"的JavaScript函數。這個函數模擬了一個文件下載過程,通過循環逐步增加<progress>元素的value屬性值,從而顯示下載進度。


          11、<meter>標簽:度量衡指示器

          <meter>標簽在HTML中用于表示度量衡指示器,它定義了一個已知范圍內的標量測量值或分數值,通常用于顯示磁盤使用情況、查詢結果的相關性等。例如:

          <p>CPU 使用率: <meter value="0.6" min="0" max="1"></meter> 60%</p>
          <p>內存使用率: <meter value="0.4" min="0" max="1"></meter> 40%</p>

          在這個示例中,我們使用了兩個<meter>標簽來分別顯示CPU和內存的使用率。value屬性表示當前的測量值,min和max屬性分別定義了測量范圍的最小值和最大值。通過這些屬性,<meter>標簽能夠清晰地顯示出資源的使用情況。



          需要注意的是,<meter>標簽不應該用來表示進度條,對于進度條的表示,應該使用<progress>標簽。


          12、<details>和<summary>標簽:詳細信息展示

          <details>和<summary>標簽是HTML5中新增的兩個元素,用于創建可折疊的詳細信息區域。

          <details>標簽定義了一個可以展開或折疊的容器,其中包含一些額外的信息。它通常與<summary>標簽一起使用,<summary>標簽定義了<details>元素的標題,當用戶點擊該標題時,<details>元素的內容會展開或折疊。

          示例:

          <details>
          <summary>點擊查看詳細信息</summary>
          <p>這里是一些額外的信息,用戶可以點擊標題來展開或折疊這些信息。</p>
          </details>

          在這個示例中,我們使用了<details>標簽來創建一個可折疊的容器,并在其中添加了一個<summary>標簽作為標題。當用戶點擊這個標題時,容器的內容會展開或折疊。


          總結:

          HTML表單標簽是構建動態網頁的基石,它們使得用戶能夠與網站進行有效的交互。


          通過合理地使用這些標簽,開發者可以創建出既美觀又功能強大的表單,從而提升用戶體驗和網站的可用性。所以說,掌握這些標簽的使用,對于前端開發者來說是至關重要的。


          我們下期再見!


          END

          文案編輯|云端學長

          文案配圖|云端學長

          內容由:云端源想分享

          CSS樣式是表現。就像網頁的外衣。比如,標題字體、顏色變化,或為標題加入背景圖片、邊框等。所有這些用來改變內容外觀的東西稱之為表現。
          JavaScript是用來實現網頁上的特效效果。如:鼠標滑過彈出下拉菜單。或鼠標滑過表格的背景顏色改變。還有焦點新聞(新聞圖片)的輪換。可以這么理解,有動畫的,有交互的一般都是用JavaScript來實現的。


          1、tml的固定結構

          一個HTML文件是有自己固定的結構的。
          <html>
          <head>...</head>
          <body>...</body>
          </html>

          代碼講解:

          <html></html>稱為根標簽,所有的網頁標簽都在<html></html>中。
          <head>

          標簽用于定義文檔的頭部,它是所有頭部元素的容器。


          頭部元素有<title>、<script>、 <style>、<link>、 <meta>等標簽,頭部標簽在下一小節中會有詳細介紹。

          在<body>和</body>標簽之間的內容是網頁的主要內容,如<h1>、<p>、<a>、<img>等網頁內容標簽,在這里的標簽中的內容會在瀏覽器中顯示出來。


          我自己是一名從事了多年開發的web前端老程序員,目前辭職在做自己的web前端私人定制課程,今年年初我花了一個月整理了一份最適合2019年學習的web前端學習干貨,各種框架都有整理,送給每一位前端小伙伴,想要獲取的可以關注我的頭條號并在后臺私信我:前端,即可免費獲取。

          2、<head>標簽的作用

          文檔的頭部描述了文檔的各種屬性和信息,包括文檔的標題等。絕大多數文檔頭部包含的數據都不會真正作為內容顯示給讀者。

          下面這些標簽可用在 head 部分:

          <head>
          <title>...</title>
          <meta>
          <link>
          <style>...</style>
          <script>...</script>
          </head>


          3、<title>標簽

          在<title>和</title>標簽之間的文字內容是網頁的標題信息,它會出現在瀏覽器的標題欄中。網頁的title標簽用。網頁制作學習交流群,四九四零六,四九三四。
          于告訴用戶和搜索引擎這個網頁的主要內容是什么,搜索引擎可以通過網頁標題,迅速的判斷出網頁的主題。每個網頁的內容都是不同的,每個網頁都應該有一個獨
          一無二的title。


          例如:
          <head>
          <title>hello world</title>
          </head>
          <title>標簽的內容“hello world”會在瀏覽器中的標題欄上顯示出來,



          4、標簽的用途

          我們學習網頁制作時,常常會聽到一個詞,語義化。那么什么叫做語義化呢,說的通俗點就是:明白每個標簽的用途(在什么情況下使用此標簽合理)比如,網頁上
          的文章的標題就可以用標題標簽,網頁上的各個欄目的欄目名稱也可以使用標題標簽。


          文章中內容的段落就得放在段落標簽中,在文章中有想強調的文本,就可以使
          用 em 標簽表示強調等等。

          講了這么多語義化,但是語義化可以給我們帶來什么樣的好處呢?


          ① 更容易被搜索引擎收錄。

          ②.更容易讓屏幕閱讀器讀出網頁內容。

          家好,我是Echa。

          三天前小編也發布了一篇關于CSS優秀在線工具大全:48個高顏值的CSS在線工具大全,對不太會寫CSS3對小伙伴們來說,那簡直就是雪中送炭。部分粉絲們還特意私信小編表示感謝。

          不過有一部分粉絲們私信小編說,2022年關于CSS官方又都更新了哪些新的知識點?其實小編也是在之前文章陸續有發布,只是新關注的粉絲們不知道,這個小編也不怪你們。咱們就一起回顧回顧。

          2022 年 CSS 新增了很多特性,例如容器查詢、父選擇器、子網格、級聯層、新視口單位等,多項期待已久的功能已集成到常青瀏覽器(自動升級到最新版本的瀏覽器,包括 Chrome、Edge、Firefox 和 Safari)中。下面就來看看 2022 年 CSS 新增的 10 個實用功能吧!

          全文大綱

          1. 顏色相關
          2. 全新動態視口單位
          3. @container:容器查詢
          4. @layer:級聯層
          5. :has:父選擇器
          6. :focus-visible 焦點選擇器
          7. color-scheme
          8. accent-color
          9. scale、rotate、translate
          10. subgrid:子網格

          1. 顏色相關

          下面來看看和 CSS 顏色相關的一些更新。CSS 工作組有兩個新規范將改變我們在 Web 上使用顏色的方式:CSS Color Module Level 4(候選推薦)和 CSS Color Module Level 5(工作草案)。兩者仍處于實驗階段,截至 2022 年 12 月,只有 Safari 已實現。

          (1)新顏色函數語法

          CSS Color Module Level 4 引入了顏色函數的新語法,例如rgb()hsl()。新語法省略了逗號,依靠空格來分隔顏色空間的每個通道。它還支持可選的 alpha 參數,從而不再需要額外的顏色函數,例如rgba()hsla()。逗號分隔的形式現在被規范稱為“遺留語法”。

          /* 遺留語法 */
          background-color: hsl(270, 50%, 40%);
          color: hsla(0, 0%, 100%, 50%);
          
          /* 新語法 */
          background-color: hsl(270 50% 40%);
          color: hsl(0 0% 100% / 50%);
          

          (2)新色彩空間

          新的顏色規范為網絡添加了大量新的顏色空間:

          • HWB:色調、白度、黑度
          • LCH:亮度、色度、色調
          • CIE L * a * b*
          • Oklab
          • Oklch
          • Display P3

          這只是新增的顏色空間的一部分,其中一些色彩空間,比如 Display P3,提供了比 sRGB 空間更寬的色域,這意味著我們將可以使用更多顏色,并且這些顏色將比一直使用的顏色更鮮艷。

          (3)相對顏色語法

          CSS Color Module Level 5 通過引入相對顏色語法進一步增強了顏色函數。。此語法可以基于另一種顏色定義新顏色。可以通過首先使用 from 關鍵字定義原色,然后像往常一樣在顏色函數中指定新顏色的通道來使用它。

          當提供原始顏色時,可以訪問“通道關鍵字”,允許引用顏色空間中的每個通道。關鍵字根據使用的顏色函數而變化。對于 rgb(),有 r、g 和 b 通道關鍵字;對于 oklch(),將擁有 l、c 和 h 關鍵字。對于每個顏色函數,還有一個 alpha 通道關鍵字,它是原始顏色的 alpha 通道。

          可以在 calc() 表達式中使用這些通道關鍵字來修改原始顏色:

          /* 去色處理 */
          rgb(from tomato calc(r - 20) calc(g - 20) calc(b - 20));
          
          /* 半透明處理 */
          rgb(from tomato r g b / 50%)
          
          /* 在 oklch 中使顏色變暗 */
          oklch(from tomato calc(l - 0.1) c h);
          

          除此之外,還可以跨顏色空間定義相對顏色。當使用一個空間中最初定義的顏色并使用不同的顏色空間定義新顏色時,瀏覽器將首先將原始顏色轉換為新的顏色空間。

          下面使用 Oklch 通過將色調旋轉 120°(? 圈)來定義基于 sRGB 中定義的原色的二次色:

          --primary: #005f73;
          --secondary: oklch(from var(--primary) l c calc(h + 120));
          

          (4)color-mix()

          CSS Color Module Level 5 規范還引入了一個 color-mix() 函數,允許在不同的顏色空間中混合顏色。

          color-mix(in lch, purple 50%, plum 50%)
          

          上面代碼中,會產生 50-50 的紫色和紫紅色混合。

          2. 全新動態視口單位

          新增的 CSS 視口單元用于處理帶有動態工具欄的移動視口。

          要想調整與視口一樣大的尺寸,可以使用現有的視口單位 vw 和 vh:

          • vw:視口大小寬度的 1%;
          • vh:視口大小高度的 1%;

          下面元素的寬度為 100vw,高度為 100vh,它將完全覆蓋整個視口:

          除了 vh 和 vw,還有:

          • vmin:vw或vh中的較小者。
          • vmax:vw或vh中的較大者。

          這些單位在瀏覽器中都得到了很好的支持。雖然這些單位在桌面瀏覽器上運行良好,但在移動瀏覽器上就會存在一些問題,視口大小受動態工具欄存在與否的影響。這些是用戶界面,例如地址欄和標簽欄等。盡管視口大小可以更改,但 vw 和 vh 大小不會。因此,尺寸為 100vh 高的元素會從視口中溢出。

          當向下滾動時,這些動態工具欄將縮回。在這種狀態下,尺寸為 100vh 高的元素將覆蓋整個視口。

          為了解決這個問題,CSS 工作組規定了視口的各種狀態:

          • 大視口:視口大小假設任何動態擴展和縮回的 UA 接口被縮回。
          • 小視口:視口大小假設任何動態擴展和縮回的 UA 接口都可以擴展。

          新視口也有指定的單位:

          • 大視口的單位帶有 lv 前綴,單位為 lvw、lvh、lvi、lvb、lvmin 和 lvmax。
          • 小視口的單位帶有 sv 前綴,單位是 svw、svh、svi、svb、svmin 和 svmax。

          除非調整視口本身的大小,否則這些視口百分比單位的大小是固定的。

          除了大視口和小視口之外,還有一個動態視口,動態考慮了瀏覽器 UI:

          • 當動態工具欄展開時,動態視口等于小視口的大小。
          • 當動態工具欄縮回時,動態視口等于大視口的大小。

          它的單位帶有 dv 前綴:dvw、dvh、dvi、dvb、dvmin 和 dvmax。它們的尺寸在對應的 lv* 和 sv* 之間。

          瀏覽器對這些單位的支持情況如下:

          參考:https://web.dev/viewport-units/

          3.@container:容器查詢

          CSS 容器查詢是一種超越與視口相關的媒體查詢的方法,而可以根據元素所在的容器修改元素的行為,不僅是依賴視口大小來更改元素的樣式。

          想要使用容器查詢,首先需要在容器上定義 container-type

          main {
            container-type: inline-size;
          }
          

          還可以使用 container-name 來命名容器,如果有多層容器,這將很有用,這樣就可以更明確地了解哪些查詢會影響元素。typename 都可以使用簡寫的 container 屬性來定義,其中 name在前,并通過正斜杠與 type 分隔。

          .main {
            container: main / inline-size;
          }
          

          然后就可以使用@container開始查詢了。一旦滿足該條件,CSS 將應用于該容器內的元素。

          最后來看一個實際的應用:

          <main class="container">
            <article>...</article>
            <article>...</article>
            <article>...</article>
          </main>
          
          

          現在就可以設置一個容器查詢來更改文章樣式及其任何后代的樣式,這將基于 main 的寬度,因為它是容器元素。

          article {
            padding: 1rem;
            font-size: 1rem;
          }
          
          @container (min-width: 60ch) {
            article {
              padding: 2rem;
              font-size: 1.25rem;
            }
          }
          
          

          這樣,當文章的寬度小于 60ch 時,就會采用更小的 paddingfont-size 值。

          瀏覽器對容器查詢的支持情況如下:

          4.@layer:級聯層

          在 2022 年 2 月/3 月,所有現代瀏覽器都發布了 Cascade Layers(級聯層),可以用來控制選擇器如何交互,而不管它們的特殊性或代碼順序。下面來看一個例子:

          @layer default, theme, state;
          
          @layer default {
            button {
              background: rebeccapurple;
              color: white;
            }    
          }
          
          @layer state {
            :disabled {
              background: dimgray;
            }    
          }
          
          @layer theme {
            button.danger {
              background: maroon;
            }
          
            button.info {
              background: darkslateblue;
            }
          
            #call-to-action {
              background: mediumvioletred;
            }
          }
          

          @layer 聲明了一個_級聯層_,同一層內的規則將級聯在一起,這給予了開發者對層疊機制的更多控制。

          上面例子中定義了多個級聯層,當一個聲明中具有多個級聯層時,后定義的級聯層具有更高的優先級。因此上面例子中,state 層具有更高的優先級,即使 theme 樣式中具有更高的特定性(權重)并且在代碼中出現得更晚。

          我們還可以嵌套圖層:

          @layer reset, framework, components, utilities;
          
          @layer components {
            @layer default, theme, state;
            
            @layer state {
              /* components.state 層 */
              :disabled { background: dimgray; }    
            }
          }
          
          @layer components.state {
            /* components.state 層 */
            :focus-visible { outline: thin dashed hotpink; }
          }
          

          層按照每個層名稱首次出現在代碼庫中的順序堆疊,后面的層名稱優先于前面的層。這意味著可以允許它們隱式堆疊:

          @layer low { /* 最低層 */ }
          @layer medium { /* 中間層 */ }
          @layer high { /* 最高層 */ }
          

          或者可以像上面例子一樣,按順序引入層名稱來明確定義層順序:

          @layer low, medium, high;
          

          瀏覽器對級聯層的支持情況如下:

          可以看到,目前主流瀏覽器都支持 CSS 級聯層功能。

          5.:has:父選擇器

          :has()選擇器可以檢查父元素中是否存在特定的元素。例如,如果一個卡片組件中有圖片,就給它添加一個display:flex。這以前在 CSS 中是無法實現的,但是新的 :has() 選擇器就可以幫助我們選擇包含特定元素的父元素。

          在CSS中,我們無法根據元素中是否存在特定的元素來設置父元素的樣式,要想實現這一點,就必須創建CSS類,并根據需要進行類的切換。來看下面的例子:

          這里我們有兩種卡片:包含圖片和不包含圖片。在CSS中需要這樣做:

          /* 有圖片的卡片 */
          .card {
            display: flex;
            align-items: center;
            gap: 1rem;
          }
          
          /* 沒有圖片的卡片 */
          .card-plain {
            display: block;
            border-top: 3px solid #7c93e9;
          }
          
          <!-- 有圖片的卡片 -->
          <div class="card">
            <div class="card-image">
              <img src="awameh.jpg" alt="">
            </div>
            <div class="card-content">
              卡片內容
            </div>
          </div>
          
          <!-- 沒有圖片的卡片 -->
          <div class="card card-plain">
            <div class="card-content">
              卡片內容
            </div>
          </div>
          

          這里創建了一個類card-plain,專門用于沒有圖片的卡片,在沒有圖片時就不需要flex布局。如果使用 CSS 中的父選擇器 :has 就不需要再寫這個類,只需要使用它來檢查卡片中是否包含.card-image即可:

          .card:has(.card-image) {
            display: flex;
            align-items: center;
          }
          

          根據 CSS 規范,:has() 選擇器可以檢查父元素是否包含至少一個元素,或者一個條件,例如輸入是否獲取到焦點。

          :has() 選擇器不僅可以檢查父元素是否包含特定的子元素,還可以檢查一個元素后面是否跟有另一個元素:

          .card h2:has(+ p) { }
          

          這將檢查 <h2> 元素是否直接跟在 <p> 元素之后。

          我們也可以將它與表單元素一起使用來檢查輸入是否獲取到了焦點:

          form:has(input:focused) {
              background-color: lightgrey;
          }
          

          瀏覽器對 :has() 的支持情況如下:

          可以看到,最新版的 Chrome、Edge、Safari 都已經支持了 :has() 選擇器,而 Firfox 目前還不支持

          6.:focus-visible

          :focus-visible 是一個現代CSS 焦點選擇器。今年 3 月,Safari 15.4 發布了 :focus-visible 偽類,不久之后,它成為常青瀏覽器中使用的默認元素焦點行為。

          當元素匹配:focus偽類并且客戶端的啟發式引擎決定焦點應當可見 (在這種情況下很多瀏覽器默認顯示“焦點框”。) 時,:focus-visible 偽類將生效。

          注意:Firefox 需要通過較舊的前綴偽類 :-moz-focusring 來支持類似的功能。

          下面來看一個例子,:focus-visible 選擇器利用客戶端的行為決定是否匹配。當使用鼠標點擊控件和用鍵盤 tab 切換控件時會有所不同。

          <input value="默認樣式s"><br>
          <button>默認樣式</button><br>
          <input class="focus-only" value=":focus"><br>
          <button class="focus-only">:focus</button><br>
          <input class="focus-visible-only" value=":focus-visible"><br>
          <button class="focus-visible-only">:focus-visible</button>
          
          .focus-only:focus {
            outline: 2px solid black;
          }
          
          .focus-visible-only:focus-visible {
            outline: 4px dashed darkorange;
          }
          

          效果如下:

          這段代碼的表現如下:

          • 默認樣式:使用鍵盤控制時,input和button的邊框都是細藍色的;使用鼠標控制時,input的邊框是細藍色的,button的邊框是細黑色的;
          • :focus:無論使用鼠標控制還是鍵盤控制,input和button的邊框都是粗黑色的;
          • :focus-visible:使用鍵盤控制時,input和button的邊框都是粗橙色的;使用鼠標控制時,input的邊框是粗橙色的,button的邊框是細黑色的;

          使用這個偽類,就可以有效地根據用戶的輸入方式 (鼠標 or 鍵盤) 來展示不同形式的焦點。

          瀏覽器對 :focus-visible 的支持情況如下:

          可以看到,目前主流瀏覽器都已經支持 :focus-visible

          7.color-scheme

          color-scheme 是一個 CSS 屬性,當用戶選擇系統配色方案時(系統配色方案的常見選擇是“深色模式”和“淺色模式”),操作系統會對用戶界面進行調整。這包括表單控件、滾動條和 CSS 系統顏色的使用值。

          :root {
            color-scheme: light dark;
          }
          

          當把上面的代碼復制到樣式表中,頁面就會根據操作系統的設置的暗/亮模式來顯示不同的樣式:

          可以看到,當切換系統配色模式時,文字顏色,背景顏色,以及表單(滾動條、選擇下拉框、單選框、復選框、輸入框等)樣式都發生了變化,這樣就省去了我們很多兩種模式下的樣式定義工作。

          通常,屬性的值是以下幾種:

          color-scheme: normal;
          color-scheme: light;
          color-scheme: dark;
          color-scheme: light dark;
          

          其中:

          • normal:表示元素未指定任何配色方案,因此應使用瀏覽器的默認配色方案呈現。
          • light:表示可以使用操作系統亮色配色方案渲染元素。
          • dark:表示可以使用操作系統深色配色方案渲染元素。

          需要注意,當lightright都有時,需要light在前,right在后。要想將整個頁面配置為用戶的配色方案首選項,就可以像上面一樣,在 :root 元素上指定 color-scheme

          我們甚至可以僅在 HTML 中就可以獲得深色模式:

          <head>
            <meta name="color-scheme" content="light dark" />
          </head>
          

          瀏覽器對 color-scheme 的支持情況如下:

          8.accent-color

          accent-color 屬性可以在不改變瀏覽器默認表單組件基本樣式的前提下重置組件的顏色。該屬性目前支持以下 HTML 控件元素:

          • 復選框:<input type=”checkbox”>
          • 單選框:<input type=”radio”>
          • 范圍選擇框:<input type=”range”>
          • 進度條:<progress>

          下面來看一個例子:

          <form>
            <label>
              <input type="radio" name="radios" checked>
              單選選中
            </label>
            <label>
              <input type="radio" name="radios">
              單選未選中
            </label>
            <label>
              <input type="checkbox" checked>
              多選選中
            </label>
            <label>
              <input type="checkbox">
              多選未選中
            </label>
            <label>
              <input type="range">
              范圍
            </label>
            <label>
              <progress max="100" value="80">80%</progress>
              進度條
            </label>
          </form>
          
          :root {
            accent-color: firebrick;
          }
          
          [type="radio"],
          [type="checkbox"] {
            font-size: inherit;
            width: 0.75em;
            height: 0.75em;
          }
          
          progress,
          [type="range"] {
            font-size: inherit;
            width: 10ch;
          }
          

          效果如下:

          可以看到,這些表單元素都變成我們定義的顏色。

          需要注意,如果給表單元素設置了自定義樣式,那 accent-color 就可能會失效。例如,將進度條的 border 設置為藍色:

          progress {
            border: blue;
          }
          

          樣式會是下面這樣,其并不符合預期(進度條邊框為藍色),出現了意料之外的效果。所以,如果使用了 accent-color 定義表單樣式,就要盡量避免再給表單元素自定義其他樣式:

          瀏覽器對 accent-color 的支持情況如下:

          9.scale、rotate、translate

          2022 年 8 月,Chromium 完成了使用單個 rotate, scale, translate 屬性來對 CSS 變換進行更細粒度的控制。

          要想在 CSS 中使用變換,需要使用 transform 屬性,該屬性接受一個或多個 <transform-function>

          .target {
            transform: translateX(50%) rotate(30deg) scale(1.2);
          }
          

          在上面的代碼中,目標元素會在 X 軸上平移 50%,旋轉 30 度,最后放大到 120%。雖然這樣 transform 屬性可以正常工作,但當想要單獨更改這些值中的任何一個時,就會比較麻煩。

          比如,想要在鼠標懸浮時更改 scale 的大小,就需要將 transform 屬性中的所有函數都復制一遍,即使它們的值保持不變。

          .target:hover {
            transform: translateX(50%) rotate(30deg) scale(2);
          }
          

          而在 Chrome 104 中,就可以使用rotate, scale, translate 屬性來單獨定義變換的這些部分。使用這些屬性來重寫前面的變換示例:

          .target {
            translate: 50% 0;
            rotate: 30deg;
            scale: 1.2;
          }
          

          這樣,如果想在某些情況下單獨修改每個屬性時,就不需要再復制其他沒有變化的屬性。

          原始的 CSS 變換屬性和新屬性之間的一個主要區別是應用聲明的變換順序:

          • 使用 transform 時,變換函數會按照它們編寫的順序,從左到右;
          • 使用單獨的變換屬性時,順序不是聲明的順序。而始終是:首先平移,然后旋轉,最后縮放。

          這意味著以下兩端代碼的執行結果是一樣的:

          .transform-individual {
            translate: 50% 0;
            rotate: 30deg;
            scale: 1.2;
          }
          
          .transform-individual-alt {
            rotate: 30deg;
            translate: 50% 0;
            scale: 1.2;
          }
          

          在這兩種情況下,目標元素都會首先在 X 軸上平移 50%,然后旋轉 30 度,最后縮放 1.2。

          如果其中一個單獨的變換屬性與 transform 屬性一起聲明,則首先應用單獨的變換(rotate, scale, translate),最后應用 transform

          瀏覽器對 rotate, scale, translate 的支持情況如下:

          10.subgrid:子網格

          subgrid 允許元素在行軸或列軸上繼承其父元素的網格,主要解決當網格嵌套網格時,子網格的位置和軌道不能和父網格對齊的問題。使用子網格時,需要讓 grid-template-columnsgrid-template-rows 屬性的值使用 subgrid 關鍵字。

          • grid-template-rows:基于網格行維度,定義網格線的名稱和網格軌道的尺寸大小。
          • grid-template-columns:基于網格列維度,定義網格線的名稱和網格軌道的尺寸大小。

          下面來看一個例子,有一個嵌套網格,它正在為行和列創建自己的軌道。這些軌道是獨立的,因此不會與父網格上的軌道對齊。

          <div class="grid">
            <div class="child"></div>
            <div class="child"></div>
            <div class="child"></div>
            <div class="child"></div>
            <div class="child"></div>
            <div class="subgrid">
              <div class="child"></div>
              <div class="child"></div>
            </div>
          </div>
          
          .subgrid {
            grid-column: auto / span 3;
            display: grid;
            gap: 10px;
            grid-template-columns: 1fr 1fr;
          }
          
          .grid {
            display: grid;
            grid-template-columns: 1fr 1fr 1fr 1fr;
            grid-auto-rows: minmax(100px, auto);
            max-width: 800px;
            margin: 2em auto;
            gap: 10px;
            padding: 10px;
            background-color: rgba(255,255,255,.8);
          }
          
          .grid > div {
            background-color: #2B3745;
            padding: 10px;
          }
          
          .subgrid > div {
            background-color: #D9D9E5;
          }
          

          上面代碼的效果如下:

          下面將 grid-template-columns 的軌道列表替換為 subgrid 關鍵字。嵌套網格的列軌道現在與父級上的列軌道對齊。

          .subgrid {
            grid-template-columns: subgrid;
          }
          

          更改完之后的效果如下:

          只要父級本身就是一個網格,就可以繼續將子網格繼承到子級中。以下示例顯示了三個網格,每個網格都嵌套在另一個網格中,并繼承了其父級的軌道。子項指示哪個網格是它們的父項。

          <div class="one">
            <div class="child">Parent one</div>
            <div class="two">
              <div class="child">Parent two</div>
              <div class="three">
                <div class="child">Parent three</div>
              </div>
            </div>
          </div>
          
          .one {
            display: grid;
            grid-template-columns: repeat(8,1fr);
            max-width: 800px;
            margin: 2em auto;
            gap: 10px;
            padding: 10px;
            background-color: rgba(255,255,255,.8);
          }
          
          .two {
            grid-column: 2 / 8;
            grid-row: 2 ;
            display: grid;
            grid-template-columns: subgrid;
            border: 2px solid #96060A;
          }
          
          .three {
            display: grid;
            grid-column: 2 / 6;
            grid-row: 2;
            grid-template-columns: subgrid;
            border: 2px solid #1C2E01;
          }
          
          .child {
            background-color: #2B3745;
            padding: 10px;
            color: #fff;
          }
          

          使用 Firefox DevTools 突出顯示每個網格,突出顯示外部網格顯示子網格和網格項如何與該網格對齊:

          瀏覽器對子網格的支持情況如下:


          主站蜘蛛池模板: 国产一区二区三区免费视频| 国产精品无码一区二区三区免费| 亚洲一区二区三区乱码在线欧洲| 亚洲国产视频一区| 久久一区二区明星换脸| 国产成人久久精品一区二区三区| 国产高清不卡一区二区| 中文无码AV一区二区三区| 午夜影视日本亚洲欧洲精品一区| 国产成人精品一区二区三在线观看| 无码中文人妻在线一区二区三区| 无码乱码av天堂一区二区| 日韩美女在线观看一区| 久久精品国产一区| 精品日韩亚洲AV无码一区二区三区 | 无码日韩AV一区二区三区| 视频一区二区三区免费观看| 国产在线精品一区二区三区不卡 | 国产色综合一区二区三区| 成人丝袜激情一区二区| 农村人乱弄一区二区| 日本精品一区二区三区视频| 亚洲欧美国产国产一区二区三区| 国产精品久久久久久一区二区三区| 一区二区三区免费高清视频| 国产精品视频一区二区三区经 | 精品一区二区三区在线观看l| 无码人妻精品一区二区三区不卡| 久久久精品日本一区二区三区| 一区二区三区无码被窝影院| 人妻AV一区二区三区精品| 国产激情一区二区三区四区| AA区一区二区三无码精片 | 在线观看国产一区| 一区二区视频传媒有限公司| 插我一区二区在线观看| 久久亚洲一区二区| 日韩免费一区二区三区在线| 99久久无码一区人妻a黑| 亚洲综合激情五月色一区| 午夜视频一区二区|