可能你沒見過,但非常實(shí)用的 HTML 標(biāo)簽,特別是前幾個(gè)

一、center

讓你實(shí)現(xiàn)水平居中,用這個(gè)標(biāo)簽就對了,標(biāo)簽名也非常得語義化

<center>零一</center>

效果如下:


1.png

水平居中

原理也很簡單,其實(shí)就是這個(gè)標(biāo)簽自帶了 text-align: center 的樣式

二、abbr

abbr 全稱是 abbreviations,意思是縮寫。應(yīng)用場景也很簡單,為一些文章中的縮寫增加注釋

以前在文章中對于縮寫的解釋經(jīng)常會(huì)這么做:

DAU(Daily Active User),日活躍用戶數(shù) ......

那我們用 abbr 標(biāo)簽?zāi)兀?/p>

<abbr title="Daily Active User">
    DAU
</abbr>
<span>,日活躍用戶數(shù) ......</span>

展示的效果如下:


2.gif

這個(gè)標(biāo)簽就可以把全稱隱藏掉,弱化信息量,讓真正不知道該縮寫的用戶主動(dòng)去獲取縮寫的具體意思,這個(gè)在 markdown 里經(jīng)常會(huì)出現(xiàn)

三、mark

<mark/> 在 markdown 中也是很常用的,用于將包裹的文本高亮展示

<mark>高亮文本</mark>

效果如下:


3.png

如果全文統(tǒng)一高亮樣式,可以專門對 mark 標(biāo)簽進(jìn)行樣式重置,這樣就不用對你用的每個(gè) div 加一個(gè) highlight 的類名了,又不語義化,又徒增文檔大小

四、sup、sub

<sup/><sub/>分別表示上標(biāo)和下標(biāo),在 markdown 中出現(xiàn)得也很頻繁,比如數(shù)學(xué)公式和引用

<div>3<sup>[2]</sup></div>
<div>4<sub>2</sub></div>

效果如下:


4.png

上標(biāo)和下標(biāo)的樣式原理也比較簡單,主要就是利用了 vertical-aligntopsub 屬性值,然后將字號(hào)縮小,不過有現(xiàn)成的標(biāo)簽,干嘛不用呢?

五、figure

figure 是用于包裹其它標(biāo)簽的內(nèi)容的,然后再利用另一個(gè)標(biāo)簽 figcaption ,可以對包裹的內(nèi)容進(jìn)行一個(gè)文本描述,例如:

<figure>
    <img src="/media/cc0-images/elephant-660-480.jpg"
         alt="大象">
    <figcaption>這是一張大象的照片</figcaption>
</figure>
效果如下:
5.png

那要是圖片掛了呢?

6.png

再友好點(diǎn)處理,我們把 img 標(biāo)簽的 alt 屬性去掉

7.png

漂亮,終于把我一直厭煩的圖裂icon給干掉了,樣式還巨好看

當(dāng)然不止能包裹 img 標(biāo)簽,其它任何都是可以的

嘿嘿,給大家在本文來個(gè)實(shí)戰(zhàn)??,下面這個(gè)可以點(diǎn)擊,樣式也是利用了 figure 這個(gè)標(biāo)簽

8.jpg

六、progress

說到 <progress/> 這個(gè)標(biāo)簽就很有意思了,去年有段時(shí)間我做的業(yè)務(wù)里涉及到了進(jìn)度條,當(dāng)時(shí)是前同事做的,然后有一些性能問題,我就在研究如何優(yōu)化,減少進(jìn)度條改變帶來的性能問題,當(dāng)時(shí)還寫了一篇 我優(yōu)化了進(jìn)度條,頁面性能竟提高了70%

雖然最后問題時(shí)解決了,但是也有幸收到了張鑫旭大佬的評論,他告訴我 progress 這個(gè)標(biāo)簽就足夠了,既有語義化,又有進(jìn)度條的功能,性能還好,兼容性也很不錯(cuò)。后來經(jīng)過一番嘗試,還真是,當(dāng)時(shí)是我孤陋寡聞了,也安利給大家

<!-- 進(jìn)度條最大值為100,當(dāng)前進(jìn)度為60,即60% -->
<progress max="100" value="60"/>

瀏覽器自帶的樣式就已經(jīng)很好看了,效果如下:

[圖片上傳失敗...(image-f40d04-1659679369491)]

業(yè)務(wù)中我們也就可以通過控制 value 屬性,來改變進(jìn)度條的進(jìn)度了

七、area

area 這個(gè)標(biāo)簽也非常有意思,它的作用是為圖片提供點(diǎn)擊熱區(qū),可以自己規(guī)定一張圖的哪些區(qū)域可點(diǎn)擊,且點(diǎn)擊后跳轉(zhuǎn)的鏈接,也可以設(shè)置成點(diǎn)擊下載文件,我們來舉個(gè)例子:

<img src="example.png" width="100" height="100" alt="" usemap="#map">

  <map name="map">
    <area shape="rect" coords="0,0,100,50" alt="baidu" >
    <area shape="rect" coords="0,50,100,100" alt="sougou" >
  </map>

area 一般要搭配 map 標(biāo)簽一起使用,每個(gè) area 標(biāo)簽表示一個(gè)熱區(qū),例如上面代碼中,我們定義了兩個(gè)熱區(qū),熱區(qū)形狀都為rect(矩形),他們的熱區(qū)分別是:

  • 坐標(biāo) (0,0) 到 坐標(biāo) (100,50) 的一個(gè)矩形
  • 坐標(biāo) (0,50) 坐標(biāo) (100,100) 的一個(gè)矩形

我們都知道,默認(rèn)的坐標(biāo)軸是這樣的:

10.png

因此,我們劃分的兩個(gè)熱區(qū)就是:

11.png

最后再來看一下我們的實(shí)際效果:

12.gif

八、details

details 字面意思是 "詳情",在markdown里也經(jīng)常用,用該標(biāo)簽包裹了的內(nèi)容默認(rèn)會(huì)被隱藏,只留下一個(gè)簡述的文字,我們點(diǎn)擊以后才會(huì)展示詳細(xì)的內(nèi)容

<details>
  <p>我是一段被隱藏的內(nèi)容</p>
</details>

效果如下:

13.gif

這還沒有加任何一行的 js 代碼,我們點(diǎn)擊后,details 標(biāo)簽上會(huì)多一個(gè) open 的屬性,被隱藏的內(nèi)容就展示出來了

默認(rèn)情況下,簡要文字為 "詳情",想要修改這個(gè)文字,要搭配 summary 標(biāo)簽來使用

<details>
  <summary>點(diǎn)擊查看更多</summary>
  <p>我是一段被隱藏的內(nèi)容</p>
</details>

就搞定了

14.png

九、dialog

瀏覽器自帶彈窗方法 alertconfirmprompt,樣式固定且每個(gè)瀏覽器不同,同時(shí)還會(huì)阻塞頁面運(yùn)行,除了這個(gè)還提供了一個(gè) dialog 標(biāo)簽,它的使用方式有點(diǎn)類似于現(xiàn)在各大組件庫的 Modal 組件了,瀏覽器還為該標(biāo)簽提供了原生的 dom 方法:showModalclose,可以直接控制彈窗的展示和隱藏

<dialog id="dialog">
    <input type="text">
    <button id="close">ok</button>
</dialog>
<button id="openBtn">打開彈框</button>

<script>
    const dialog = document.getElementById('dialog')
    const openBtn = document.getElementById('openBtn')
    const closeBtn = document.getElementById('close')
  
    openBtn.addEventListener('click', () => {
        // 打開彈框
        dialog.showModal()
    })
    closeBtn.addEventListener('click', () => {
        // 隱藏彈框
        dialog.close()
    })
</script>

效果如下:

15.gif

細(xì)心的你有沒有發(fā)現(xiàn),這原生的彈框還自帶背景蒙層,點(diǎn)擊是關(guān)閉不掉的,但起碼它不會(huì)阻塞頁面

然后我們在彈窗展示時(shí),也可以通過 esc 鍵來關(guān)閉彈窗

十、datalist

datalist 是用于給輸入框提供可選值的一個(gè)列表標(biāo)簽,類似咱們常用的 Select 組件

我可以用其實(shí)現(xiàn)一個(gè) "輸入聯(lián)想" 的功能

<label> 輸入C開頭的英文單詞:</label>
<input list="c_words"/>

<datalist id="c_words">
  <option value="China">
  <option value="Click">
  <option value="Close">
  <option value="Const">
  <option value="Count">
</datalist>

來試一試:

16.gif

剛點(diǎn)擊時(shí)會(huì)把所有推薦的選項(xiàng)都列出來,然后根據(jù)后面輸入的內(nèi)容,會(huì)過濾掉不匹配了的選項(xiàng),比如我輸入 cl,會(huì)過濾掉不是 cl 開頭的單詞,最后只剩下 ClickClose

最后我發(fā)現(xiàn),他這個(gè)下拉框有點(diǎn)好看啊?為啥這原生的 input 框默認(rèn)樣式那么丑,啥時(shí)候改改

十一、fieldset

fieldset 標(biāo)簽是用于分組管理 form 表單內(nèi)的元素的,若 fieldset 設(shè)置了 disabled 屬性,則被其包裹的所有表單元素都會(huì)被禁用置灰,且不會(huì)隨著表單一起提交上去,是的就成了擺設(shè)

什么意思呢?看個(gè)例子:

<form action="/example">
  <fieldset disabled>
    <legend>被禁用區(qū)域</legend>
    <label>ID:</label>
    <input type="text" name="id" value="1">
    <label>郵箱:</label>
    <input type="text" name="email" value="1234567@163.com">
  </fieldset>
  <label>名字:</label>
  <input type="text" name="name">
  <button type="submit">提交</button>
</form>

這里我們把 ID郵箱 的表單包裹了起來,且設(shè)置了 disabled,只開放了一個(gè) name 的輸入控件,此時(shí)界面如下:

17.png

可以看到除了 name 輸入框,其它的兩個(gè)輸入框都被禁用了,此時(shí)點(diǎn)提交會(huì)是什么樣子呢?

18.png

嗯,只提交了 name 字段

十二、noscript

這個(gè)標(biāo)簽是在瀏覽器不支持或禁用了 javascript 時(shí)才展示的,大多用于對 js 強(qiáng)依賴的應(yīng)用,比如現(xiàn)在大部分的 SPA 頁面,一旦不支持 javascript,頁面基本上什么內(nèi)容都沒了,此時(shí)可以靠這個(gè)標(biāo)簽做友好提示

一般我們不需要特地去使用,大多都是在打包過程中自動(dòng)插入到 html 靜態(tài)文件里去了的,例如:

// init.js
const root = document.getElementById('root')
const button = document.createElement('button')
button.innerText = '點(diǎn)擊出彈窗'
root.appendChild(button)
<!-- index.html -->
<script defer src="./init.js"></script>

<noscript>
  不好意思,你的瀏覽器不支持或禁用了 JavaScript,請更換瀏覽器或啟用 JavaScript
</noscript>

<div id="root"></div>

未禁用 javascript 時(shí),頁面時(shí)這樣的:

19.png

禁用了 javascript 時(shí),是這樣的:

20.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容

  • DTD 介紹 DTD(Document Type Definition 文檔類型定義)是一組機(jī)器可讀的規(guī)則,它們定...
    lio_zero閱讀 2,685評論 0 9
  • 一、HTML簡介 1、HTML是什么? HyperTextMarkupLanguage 超文本(功能豐富)標(biāo)記(標(biāo)...
    千年幸福論閱讀 1,457評論 0 2
  • 問題記錄 有的網(wǎng)頁圖片直接復(fù)制地址粘貼之后并不能顯示?-211211 常用 HTML檢查網(wǎng)站:https://va...
    濤濤抄書閱讀 243評論 0 0
  • 1.有序列表、無序列表、自定義列表如何使用?寫個(gè)簡單的例子。三者在語義上有什么區(qū)別?在哪些情況下使用哪種(重要)?...
    freddy閱讀 498評論 0 0
  • HTML5 元素有多種維度展示方式,常見以下: 1.按照類別分類 2.按照是否Block元素 按照類別分: 根元素...
    前端漫談閱讀 158評論 0 0