搜尋
首頁web前端H5教程介紹下HTML5.1裡的新內容

 HTML 5.1概覽

  兩年前HTML5標準的發表對於web開發社群來說是一件大事。不僅是因為它包含了一系列令人印象深刻的新特性, 還因為它是1999年發布的HTML4.01標準以後,對HTML的第一個大版本更新。你現在依然可以看到一些網站誇耀他們在使用「現代」的HTML5標準。

#   幸運的是我們不需要為下一次HTML標準的更新等待那麼長時間。 2015年10月,W3C開始著手HTML5.1草案,其目標是修復一些HTML5遺留的問題。多次迭代後, 草案於2016年6月達到“候選建議(Candidate Recommendation)”階段,2016年9月達到“提議建議(Proposed Recommendation)”,最終2016年11月發布W3C 建議。關注新標準的人可能注意到了,這是一段曲折之路。很多開始提出的HTML5.1特性因為不好的設計或缺少瀏覽器廠商支援而被廢棄了。

  儘管HTML5.1仍在發展, W3C已經開始著手HTML5.2草案,該標準預計2017年末發布。本文是對HTML5.1一些有趣的新功能和提升的概覽。瀏覽器對這些特性依然缺乏支持,但是至少我們會告訴你一些支援這些特性的瀏覽器,用來測試每個範例。

  上下文選單使用menu和menuitems元素

#   HTML5.1草案介紹了兩種不同的menu元素: context和toolbar。前者用來擴展本地上下文選單,通常被頁面上的滑鼠右鍵啟動;後者用來定義一個普通的選單元件。在發展過程中,toolbar 被放棄了,但是context選單保存了下來。

  可以使用

標籤來定義一個包含一個或幾個 元素的選單,然後把它綁定到任何使用contextmenu 屬性的元素上。

  每個 可以是以下三種類型之一:

  • checkbox – 允許選擇或取消選擇一個選項(option);


  • command – 允許在按一下滑鼠時執行一個動作;


  • # radio – 允許在一組選項中選擇一個.

#   這裡有一個基本的使用例子,可以在Firefox49中運行, 但是Chrome54目前不行。

  請看SitePoint (@SitePoint)在CodePen上HTML5.1選單範例。

  在一個支援的瀏覽器上,這個上下文選單的範例應該看起來是這樣:

A HTML 5.1 context menu

#   上下文選單中有自訂項目。

  細部(Details)與總結(Summary)元素

  新的

元素可以透過滑鼠點擊實現附加資訊的展示和隱藏。這是使用JavaScript時候常在做的事,現在可以使用
元素和元素代勞了。點選元素可以顯示並隱藏details元素的其餘部分.

#   下面的例子可以在Firefox和Chrome中進行測試。

  請看SitePoint (@SitePoint)在CodePen上HTML5.1 詳情和總結 demo。

  這個demo在支援的瀏覽器上應該是下面這樣:

Details and summary elements

#   更多的input類型 - month,week 和 datetime-local

#   input擴展了三種: month, week 和datetime-local。

  前兩種讓你可以選擇週或月。在Chrome中兩者都渲染成下拉的日曆,可以選擇某週或某月。當你用JavaScript得到它們的值,你將得到一個大致這樣的字串: "2016-W43"(week input); "2016-10" (month input)。

  最初,HTML5.1草案介紹了兩種日期類型input — datetime和datetime-local。不同的是,datetime-local 使用使用者時區, 而datetime允許你選擇時區。發展過程中,datetime 被放棄了,現在只有datetime-local存在。 datetime-local input由兩部分組成 — 日期,可以像week 和 month一樣進行選擇;時間, 可以單獨輸入。

  下面是關於所有新類型input的例子,它在chrome中可以正常展示,但是firfox不行。

  請看SitePoint (@SitePoint)在CodePen上HTML 5.1 week, month 和 datetime inputs。

  這個demo在支援的瀏覽器上應該是下面這樣:

Week, month and datetime-local inputs

#   響應式圖片

#   HTML5.1包括幾個在不使用CSS情況下實現響應式圖片的新特性。每個特性都有自己單獨的使用場景。

  srcset屬性

#   srcset影像屬性允許列出多個可用於替代的圖片資料來源,這些資料來源的像素密度不同。這使得瀏覽器可以針對使用者裝置選擇合適品質的圖片(由裝置的像素密度、縮放比例或網路速度決定)。例如,在低速手機網路和小螢幕手機的情況下,應該為使用者提供低像素的圖片。

  srcset屬性接受一個用逗號分隔的URL列表,每個URL帶有一個表示最接近所請求圖片像素比(一個CSS像素所代表的物理像素數量)的修飾x。以下是一個簡單的範例:

<img  src="/static/imghwm/default1.png" data-src="images/low-res.jpg" class="lazy" alt="介紹下HTML5.1裡的新內容" >

在這個例子中,如果用戶設備的像素比是1,圖片low-res將會被展示;如果是2,圖片high-res將會被展示;如果是3或者更大,圖片ultra-high-res將會被展示。

  或者,你可以選擇將圖片展示成不同尺寸。這需要使用w:

<img  src="/static/imghwm/default1.png" data-src="images/low-res.jpg" class="lazy" alt="介紹下HTML5.1裡的新內容" >

  在這個例子中,圖片low-res被定義成600px寬,圖片high-res被定義成1000px寬,ultra-high-res是1400px寬。

  sizes屬性

#   你可能想根據使用者螢幕尺寸來使用不同方式展示圖片。例如,你可能想在寬螢幕上用兩欄展示圖片,窄一些的螢幕上用一欄。這點用sizes屬性就可以實現。它允許你為圖片分配螢幕的寬度,然後透過srcset屬性選擇合適的圖片。下面是一個例子:

<img  src="/static/imghwm/default1.png" data-src="images/low-res.jpg" class="lazy" alt="介紹下HTML5.1裡的新內容" >

  當視口寬度大於40em時,sizes屬性把圖片的寬度定義為視口寬度的50%;當視口(viewport)寬度小於或等於40em時,把圖片寬度定義為視口寬度的100%。

  picture元素

#   如果根據螢幕不同改變圖片的尺寸還是無法滿足需求,你想根據螢幕不同展示不同的圖片,那就需要使用picture元素。它允許你透過用指定多個不同元素,來為不同尺寸的螢幕定義不同資源的圖片。 元素作為URL載入圖片的來源。

<picture>
  <source>
  <source>

  <img  src="/static/imghwm/default1.png" data-src="images/large/low-res.jpg" class="lazy" alt="介紹下HTML5.1裡的新內容" >
</source></source></picture>

  如果你想知道更多關於響應式圖片的東西,請戳How to Build Responsive Images with srcset.

  用form.reportValidity()驗證表單

#   HTML5定義的form.checkValidity()方法可以檢查表單是否符合事先定義好的驗證器然後傳回一個布林值。新的reportValidity() 方法很相似 — 它也可以檢驗一個表單並傳回結果,但是它也能為使用者報告錯誤。以下是一個範例(請在Firefox或Chrome中測試):

#   請在CodePen上看SitePoint (@SitePoint)的範例HTML 5.1 report validity demo。

  "First name"輸入框被要求非空,如果不填寫它將被標記有錯誤。如果符合預期,它將是這樣:

Working form validation with a message

#   frames的AllowfullscreenFrames的Allowfullscreen屬性

#   frames新的布林屬性allowfullscreen可以控制內容是否可以透過requestFullscreen()方法全螢幕展示內容。

  使用element.forceSpellCheck()進行拼字檢查

  新的element.forceSpellCheck()方法允許你在text元素上觸發拼字檢查。這也是本文所列出的所有特性中第一個還不被任何瀏覽器支援的特性。也許,這可以用來進行檢查還沒有被使用者直接編輯的元素。

  沒有寫入HTML5.1的特性

#   一些特性在第一版的草案中被定義但是最終被刪除了,大部分原因是瀏覽器廠商缺乏興趣。以下是其中一些有趣的方法:

  inert屬性

#   inert屬性可以停用所有子元素的使用者交互,就像給所有子元素都加了disabled屬性。

  dialog元素

#

元素提供一個原生的彈出框,它甚至有一個方便的表單集合- 在上使用method屬性可以阻止表單提交到伺服器上,而是關閉彈出框並把結果傳回彈出框的建立者。

  這個特性似乎在firfox仍然支持,所以可以看看下面這個例子(譯者註:firfox V49.0.2不支持:

  請看SitePoint (@SitePoint)在CodePen的範例 HTML dialog element。

More articles from the author

  • Up and Running with ESLint — the Pluggable JavaScript Linter


  • Visual Regression Testing with PhantomCSS

以上是介紹下HTML5.1裡的新內容的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
掌握microdata:HTML5的分步指南掌握microdata:HTML5的分步指南May 14, 2025 am 12:07 AM

Microdatainhtml5enhancesseoanduserexperienceByByBybyBystructuredDatatoSearchEngines.1)useIteMscope,itemType,anditempropattributestomarkupcontentlikeSoreRoductSssSssSoRorevents.2)

HTML5表格中有什麼新功能?探索新輸入類型HTML5表格中有什麼新功能?探索新輸入類型May 13, 2025 pm 03:45 PM

html5introducesnewinputtypesthatenhanceSerexperience,簡化開發和iMproveAccessibility.1)自動validatesemailformat.2)優化優化,優化OmportizeSmizesemizesemizesemizesemizesemizeSmobobileWithAnumericKeyPad.3)和Simimplifydateandtimeputientupits,並重新替代了Forcustemolcustemolcustene。

理解H5:含義和意義理解H5:含義和意義May 11, 2025 am 12:19 AM

H5是HTML5,是HTML的第五個版本。 HTML5提升了網頁的表現力和交互性,引入了語義化標籤、多媒體支持、離線存儲和Canvas繪圖等新特性,推動了Web技術的發展。

H5:可訪問性和網絡標準合規性H5:可訪問性和網絡標準合規性May 10, 2025 am 12:21 AM

無障礙訪問和網絡標準遵循對網站至關重要。 1)無障礙訪問確保所有用戶都能平等訪問網站,2)網絡標準遵循提高網站的可訪問性和一致性,3)實現無障礙訪問需使用語義化HTML、鍵盤導航、顏色對比度和替代文本,4)遵循這些原則不僅是道德和法律要求,還能擴大用戶群體。

HTML中的H5標籤是什麼?HTML中的H5標籤是什麼?May 09, 2025 am 12:11 AM

HTML中的H5標籤是第五級標題,用於標記較小的標題或子標題。 1)H5標籤幫助細化內容層次,提升可讀性和SEO。 2)結合CSS可定製樣式,增強視覺效果。 3)合理使用H5標籤,避免濫用,確保內容結構邏輯性。

H5代碼:Web結構的初學者指南H5代碼:Web結構的初學者指南May 08, 2025 am 12:15 AM

HTML5構建網站的方法包括:1.使用語義化標籤定義網頁結構,如、、等;2.嵌入多媒體內容,使用和標籤;3.應用表單驗證和本地存儲等高級功能。通過這些步驟,你可以創建一個結構清晰、功能豐富的現代網頁。

H5代碼結構:組織內容以實現可讀性H5代碼結構:組織內容以實現可讀性May 07, 2025 am 12:06 AM

通過合理的H5代碼結構可以讓頁面在眾多內容中脫穎而出。 1)使用語義化標籤如、、等組織內容,使結構清晰。 2)通過CSS佈局如Flexbox或Grid控制頁面在不同設備上的呈現效果。 3)實現響應式設計,確保頁面在不同屏幕尺寸上自適應。

H5與較舊的HTML版本:比較H5與較舊的HTML版本:比較May 06, 2025 am 12:09 AM

HTML5(H5)與舊版本HTML的主要區別包括:1)H5引入了語義化標籤,2)支持多媒體內容,3)提供離線存儲功能。 H5通過新標籤和API增強了網頁的功能和表現力,如和標籤,提高了用戶體驗和SEO效果,但需注意兼容性問題。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器