22個HTML5的初級技巧

来源:http://www.cnblogs.com/shouce/archive/2016/02/17/5194248.html
-Advertisement-
Play Games

Web技術的發展速度太快了,如果你不與時俱進,就會被淘汰。因此,為了應對即將到來的HTML5,本文總結了22個HTML5的初級技巧,希望能對你進一步學習好HTML5會有所幫助。 1. 新的Doctype聲明 XHTML的聲明太長了,我相信很少會有前端開發人員能手寫出這個Doctype聲明。 1 <!


Web技術的發展速度太快了,如果你不與時俱進,就會被淘汰。因此,為了應對即將到來的HTML5,本文總結了22個HTML5的初級技巧,希望能對你進一步學習好HTML5會有所幫助。

1. 新的Doctype聲明

XHTML的聲明太長了,我相信很少會有前端開發人員能手寫出這個Doctype聲明。

1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
2 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

HTML5的Doctype聲明很短,看到這個聲明相信你馬上就能記住,不用浪費腦細胞去記那長的有點變態的XHTML的Doctype聲明瞭。

1 <!DOCTYPE html>

HTML5的簡短的DOCTYPE聲明是讓Firefox、Chrome等現代瀏覽器和IE6/7/8等瀏覽器都進入(準)標準模式,你可能會奇怪IE6/7居然也可以支持HTML5 Doctype,事實上,IE是只要doctype符合 這種格式,都會進入標準模式。

2. <figure>標簽

看看下麵一段簡單的代碼:

1 <img src="path/to/image" alt="About image"
2 <h6>Image of Mars.</h6>

遺憾的是,這裡的h6標簽和img標簽好像沒有什麼關係,語義不夠明確。HTML5意識到了這一點,於是就採用了<figure>標簽。當<figure>結合<figcaption>標簽的使用,可以讓h6標簽和img標簽組合起來,代碼就更具語義化了。

1 <figure>
2    <img src="path/to/image" alt="About image"
3 <figcaption>
4 <h6>This is an image of something interesting. </h6>
5 </figcaption>
6 </figure>

3. 重新定義<small>

不久前,我使用了<small>標簽來創建與logo相關的副標題。但是在HTML5中重新定義了<small>標簽,使之更能表現語義化,在<small>的字型大小都會變小,想想如果這個標簽用於網站的底部的版權信息還是個不錯的做法。

4. 去掉了Javascript和CSS標簽的type屬性

通常你會在<link>和<script>加上type屬性:

1 <link rel="stylesheet" href="path/to/stylesheet.css" type="text/css">
2  <script type="text/javascript" src="path/to/script.js"></script>

在HTML5中,不再需要type屬性了,因為這顯得有點多餘,去掉之後可以讓代碼更為簡潔。

1 <link href="path/to/stylesheet.css">
2  <script src="path/to/script.js"></script>

5. 是否使用雙引號

這有點讓人糾結,HTML5並不是XTHML,你可以省去標簽中的雙引號。相信大多數同志也包括我都習慣了加上雙引號,因為這讓代碼看起來會更標準。不過,這可以根據你的個人喜好來確定是到底要不要雙引號。

1 <h6 class="myClass" id="someId"> Start the reactor.  </h6>

6. 使網頁內容可以編輯

HTML5 可編輯的內容

這是HTML5新增的一個功能,在標簽中加上一個contenteditable屬性,並且設置值為true,就可以直接在頁面上編輯這個標簽的內容,包括這個標簽的子級標簽的內容。有了這個屬性,你可以利用這個屬性完成很多事,比如在網頁中編輯一個待辦事項的清單。

1 <h6 contenteditable="true">Break mechanical cab <span>driver</span></h6>

7. 電子郵件輸入框

HMTL5中新增了一個輸入框的電子郵件屬性,可以檢測輸入的內容是否符合電子郵件的書寫格式,功能越來越強大了吧,在HTML5之前只能依靠JS來檢測。雖然內置的表單驗證功能很快就會成為現實,但這個屬性很多瀏覽器都還不支持,只會當作普通的文本輸入框來處理。

1 <form method="get">
2   <label for="email">Email:</label>
3 <input id="email" name="email" type="email">
4   <button> Submit Form </button>
5 </form>
HTML5 電子郵件輸入框

到目前為止,包括現代瀏覽器在內都不支持該屬性,所以這個屬性暫時還是靠不住的。

8. 占位符

文本框中的占位符(看看本博的搜索框效果)有利於提升用戶體驗,之前,我們只能依靠JS來實現占位符的效果,在HTML5中新增了占位符屬性placeholder。

1 <input name="email" type="email"placeholder="[email protected]">

同樣,目前的主流現代瀏覽器對該屬性的支持不大好,暫時只有Chrome和Safari支持該屬性,Firefox和Opera不支持該屬性。

HTML5 占位符

9. 本地存儲

HTML5的本地存儲功能,可以讓現代瀏覽器“記住”我們輸入的,就算瀏覽器關閉和刷新也不會受影響。雖然這個功能有些瀏覽器不支持,但是IE8, Safari 4, 還有 Firefox 3.5還是支持這個功能的,你可以測試下。

HTML5 本地存儲

10. 更有語義的header和footer

下麵的代碼在HTML5中將不復存在

1 <div id="header">
2      ...
3 </div>
4 <div id="footer">
5      ...
6 </div>

通常我們都會給header和footer定義一個div,然後再添加一個id,但是在HTML5中可以直接使用<header>和<footer>標簽,所以可以將上面的代碼改寫成:

1 <header>
2     ...
3 </header>
4 <footer>
5     ...
6 </footer>

要註意不要將這兩個標簽和網站的頭部和頁腳混淆起來,它們只是代表它們的容器。

11. IE對HTML5的支持

IE瀏覽器目前對HTML5的支持並不好,也是阻礙HTML5的更快普及的一大絆腳石,不過,IE9對HTML5的支持度還是很不錯的。

IE把HTML5新增的標簽都解析成內聯元素,而實際上它們是塊級元素,所以有必要為它們定義一個樣式:

1 header, footer, article, section, nav, menu, hgroup {
2    display: block;
3 }

儘管如此,IE還是不能解析這些新增的HTML5標簽,這個時候就需要藉助Javascript來解決這個問題:

1 document.createElement("article");
2 document.createElement("footer");
3 document.createElement("header");
4 document.createElement("hgroup");
5 document.createElement("nav");
6 document.createElement("menu");

你可以藉助這一段Javascript代碼來修複IE更好的解析HTML5

1 <!--[if IE]>
2  <script mce_src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
3  <![endif]-->

12. 標題群( hgroup)

這個類似於第二點技巧。如果用h1和h2標簽分別表示網站的名稱和副標題,但這會讓兩個本義上密切相關的標題並沒有關聯起來。這個時候可以使用<hgroup>標簽將它們組合起來,這樣代碼會更有語義。

1 <header>
2 <hgroup>
3 <h1> Recall Fan Page </h1>
4 <h2> Only for people who want the memory of a lifetime. </h2>
5 </hgroup>
6 </header>

13. 必填項屬性

前端人員肯定做過不少表單驗證的項目,其中很重要的一點就是有些輸入框的內容是必須填寫的,這裡就需要使用Javascript來檢查。在HTML5中,新增了一個“必須填寫”的屬性:required。required屬性有兩種使用方法,第二種方法顯得更有結構性,而第一種更簡潔。

1 <input type="text" name="someInput" required>
1 <input type="text" name="someInput" required="required">

有了這個屬性,使表單的提交驗證變得更簡單了,看看下麵簡單的例子:

1 <form method="post">
2     <label for="someInput"> Your Name: </label>
3 <input id="someInput" name="someInput" type="text" placeholder="Douglas Quaid" required="required">
4     <button>Go</button>
5 </form>
HTML5 必填項屬性

如果輸入框為空,表單將無法提交成功。

14. 自動獲取焦點

同樣的,HTML5也不再需要Javascript來解決輸入框的自動獲取焦點,如果某個輸入框應當被選擇或是獲取到輸入焦點,HTML5新增了自動獲取焦點屬性autofocus:

1 <input type="text" name="someInput" placeholder="Douglas Quaid"required="required" autofocus="autofocus">

autofocus也同樣可以寫成”autofocus=autofocus”,這樣看起來標準些,這個根據自己的個人喜好而定。

15. 音頻播放的支持

HTML5中提供了<audio>標簽,解決了以往必須依靠第三方插件才能播放音頻文件的問題。目前為止,還只有少數的最新瀏覽器支持該標簽。

1 <audio autoplay="autoplay" controls="controls">
2     <source src="file.ogg">
3     <source src="file.mp3">
4     <a href="file.mp3">Download this file.</a>
5 </audio>

為什麼會有兩種格式的音頻文件?因為Firefox和Webkit瀏覽器所支持的格式存在差異,Firefox只能支持.ogg文件,而Webkit只支持.mp3的文件,解決的辦法就是創建兩個版本的音頻文件,這樣就可以相容Firefox和Webkit的瀏覽器了,需要註意的是IE不支持該標簽。

16. 視頻播放的支持

和<audio>標簽一樣,HTML5也提供了<video>標簽對播放視頻文件的支持。YouTube也宣佈了一項新的HTML5的視頻嵌入。不過有點遺憾,HTML5的規範並沒有指定特定的視頻解碼器,而是讓瀏覽器自己來決定。這就造成了個瀏覽器的相容問題,雖然Safari和IE9都支持還H.264格式的視頻( Flash 播放器可以可以播放),Firefox和Opera則支持開源的Theora和Vorbis格式。因此,當顯示HTML5視頻的時候,也得準備2種格式。

1 <video controls="" preload="">
2     <source src="cohagenPhoneCall.ogv" type="video/ogg; codecs='vorbis, theora'">
3     <source src="cohagenPhoneCall.mp4" type="video/mp4; 'codecs='avc1.42E01E, mp4a.40.2'"
4 <div> Your browser is old. <a href="cohagenPhoneCall.mp4">Download thisvideo instead.</a> </div>
5  
6 </video>

需要註意的是,type屬性雖然可以省略掉,但是如果加上的話,瀏覽器就可以更快的準確的解析該視頻文件。並不是所有的瀏覽器都支持HTML5的視頻,所以得做好使用Flash版本來代替,當然,這個決定權在於你。

17. 預載入視頻

預載入屬性:preload,首先要確定是否需要預先載入視頻,假如,訪客在訪問一個有很多視頻展示的頁面,那麼就有必要預先載入一段視頻,這樣可以節省訪客的等待時間,提高用戶體驗。你可以給<video>標簽添加一個preload屬性來實現預先載入的功能。

1 <video preload="preload">
2  ...
3 </video>

18. 顯示控制項 顯示控制項屬性可以給視頻添加一個播放暫停的控制項,需要註意的是每個瀏覽器顯示的效果可能會有些差異。

1 <video preload="preload" controls="controls">
2 ...
3 </video>

19. 使用正則表達式

在HTML5中,我們可以直接使用正則表達式。

1 <form action="" method="post">
2     <label for="username">Create a Username: </label> 
3 <input type="text" name="username" id="username" placeholder="4 <> 10"pattern="[A-Za-z]{4,10}" autofocus="autofocus" required="required">
4     <button type="submit">Go </button>
5 </form>

20. 檢測瀏覽器對HTML5屬性的支持

由於各瀏覽器對HTML5屬性的支持度不同,這就造成了一些相容問題。但是可以使用方法來檢測該瀏覽器是否支持這些屬性,上例中的代碼如果要檢測pattern屬性是否被瀏覽器識別,可以使用Javascript代碼來檢測。

1 alert( 'pattern' in document.createElement('input') ) // boolean;

其實這是確定瀏覽器相容常用的方法,jQuery庫就經常使用這種方法。上面的代碼中創建了一個input標簽,並檢測pattern屬性是否被瀏覽器支持,如果能支持的話,瀏覽器就支持這個功能,否則就不支持。

1 <script> 
2  if (!'pattern' in document.createElement('input') ) { 
3     // do client/server side validation 
4  
5 </script>

21. Mark標簽

<mark>標簽用於高亮顯示那些需要在視覺上向用戶突出其重要性的文字,包裹在此標簽里的字元串必須與用戶當前的行為相關。例如,如果我在一些博客中搜索“Open your Mind” ,我可以使用在<mark>標簽里使用JavaScript 來包裹每一次動作。

1 <h3> Search Results </h3>
2 <h6> They were interrupted, just after Quato said, <mark>"Open your Mind"</mark>. </h6>

22. 該如何正確的使用div標簽

有些人可能會有疑問,有了<header>和<footer>等這些標簽,<div>標簽在HTML5中還有用嗎?答案是肯定的,比如你想創建一個能包裹特殊內容的容器自由靈活的<div>肯定是首選,而你要創建一篇文章或者一個導航菜單,建議你使用更有語義的<article>和<nav>標簽。

很多人認為HTML5可能還是很遙遠的事,所以直接無視,其實不然,現在很多網站都已經開始使用HTML5了,事實上,HTML5的一些新增屬性和功能是讓代碼變得更簡潔,這總歸是一件好事,應該值得我們推崇。最後感謝你閱讀了這篇HTML5的入門級文章,希望能為你進一步學習HTML5提供一些幫助。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • [原文鏈接] https://www.huangwenchao.com.cn/2015/03/html5-image-preview.html 問題 加入我們在 HTML 裡面有一個圖片上傳控制項: <input id="upload_image" type="file" name="image" a
  • 心心念念的新年過完了~卻沒念到年會,更沒念到年終獎~哎,以任何理由不發年終獎的公司都是臭流氓~然,我們公司沒有理由,壓根兒就沒提這事,哇卡卡卡卡!!! ======================== 華麗麗的跳水線=========================== 年後第一天,公司人不多,閑來
  • Media Queries 詳解
  • 前段時間由於工作需要寫了一個純JS文本比較工具 在這裡與大家分享下 演算法有待優化,還希望大家多多指教 先上效果圖: 奉上源碼(把源碼保存為html格式的文件就可以直接運行了): 1 <!doctype html> 2 <html> 3 <head> 4 <title>文本比較工具</title> 5
  • 接觸 DeviceOne 要從15年11月開始說起了,因項目和產品時間需求接觸了快速開發平臺,DeviceOne是非常棒的一個平臺,雙向數據綁定,可以自定義指令,過濾器等等。總之非常好用完全超出了我們功能需求。之後我們使用了混合型開發平臺,沒有達到原生App的體驗和流暢,在頁面切換以及頁面滾動的時候
  • 查看效果:http://hovertree.com/code/javascript/pwl4bhoi.htm 代碼如下: 1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html;
  • 這是一款基於jQuery和CSS3的登錄表單,登錄表單的界面整體呈現扁平化風格,非常簡潔和清新。當焦點在表單的輸入欄位上時,表單提示文字會出現一個小動畫,同時這款CSS3登錄表單的最大特點是其個性化的登錄按鈕,滑鼠滑過也有不錯的效果。 線上預覽 源碼下載 實現的代碼。 html代碼: <div cl
  • 1.0 作者:cloudgamer http://www.cnblogs.com/cloudgamer/archive/2010/04/01/ImageZoom.html
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...