概念:html
HTML5 是繼 HTML4.01, XHTML 1.0 和 DOM 2 HTML 後的又一個重要版本,html5
旨在消除富 Internet 程序(RIA)對 Flash, Silverlight, JavaFX 一類瀏覽器插件的依賴。canvas
1991年HTML1.0標準出現
1997年HTML4.0發佈,4.0標準下的瀏覽器侷限性
Flash (安全與穩定堪憂、耗電、觸摸、不開放)
Silverlight
JavaApplet
2008年HTML5出現, W3C2014年10月29日,萬維網聯盟宣佈,通過接近8年的艱苦努力,該標準規範終於制定完成。跨域
HTML5加強了瀏覽器的原生功能,符合HTML5規範的瀏覽器功能將更增強大,減小了Web應用對插件的依賴,瀏覽器
讓用戶體驗更好,讓開發更加方便,另外W3C從推出HTML4.0到5.0之間共經歷了17年,HTML的變化很小,這並不符合一個好產品的演進規則。安全
1)、在文檔類型聲明上
html:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
html5:
<!doctype html>
2)、在文檔聲明上:
html有很長的一段代碼,而且很難記住這段代碼,而html5卻不一樣,只有簡簡單單的聲明,這也方便人們的記憶。ruby
3)、在結構語義上
html: 沒有體現結構語義化的標籤,一般都是這樣來命名的<div id="header"></div>,這樣表示網站的頭部。
html5: 在語義上卻有很大的優點。提供了一些新的標籤,好比:<header><article><footer>。服務器
支持Html5的瀏覽器包括Firefox(火狐瀏覽器),IE9及其更高版本,Chrome(谷歌瀏覽器),Safari,Opera;app
一、語義特性(Class:Semantic)ide
HTML5會賦予網頁更好的意義和結構。更加豐富的標籤將隨着對RDFa、微數據、微格式、等方面的支持,構建對程序、對用戶更有價值的數據驅動Web。
二、本地存儲特性(Class: OFFLINE & STORAGE)
基於HTML5開發的網頁APP擁有更短的啓動時間,更快的聯網速度,這全得益於HTML5 APP Cache、本地存儲功能、Indexed DB(HTML5本地存儲最重要的技術之一)和API說明文檔。
三、設備兼容特性 (Class: DEVICE ACCESS)
從Geolocation功能的API文檔公開以來,HTML5爲網頁應用開發者提供了更多功能上的優化選擇,帶來了更多體驗功能。HTML5提供了史無前例的數據與應用接入開放接口。使外部應用可直接與瀏覽器內部的數據直接相連,譬如:視頻影音可直接與microphones及攝像頭相聯。
四、鏈接特性(Class: CONNECTIVITY)
更有效的鏈接效率,使得基於頁面的實時聊天,更快速的網頁遊戲體驗,更優化的在線交流獲得實現。HTML5擁有更有效的服務器推送技術,Server-Sent Event和WebSockets就是其中的兩個特性,這兩個特性能幫助咱們實現服務器將數據「推送」到客戶端的功能。
五、網頁多媒體特性(Class: MULTIMEDIA)
支持網頁端的Audio、Video等多媒體功能,與網站自帶的APPS、攝像頭、影音功能相得益彰。
六、三維、圖形、特效特性(Class: 3D, Graphics & Effects)
基於SVG、Canvas、WebGL、CSS3的3D功能,用戶會驚歎於在瀏覽器中,所呈現的驚人視覺效果。
七、性能、集成特性(Class: Performance & Integration)
沒有用戶會永遠等待你的Loading——HTML5會經過XML Http Request 2等技術,解決之前的跨域問題,幫Web應用和網站在多樣化的環境中更快速工做。
八、CSS3特性(Class: CSS3)
在不犧牲性能和語義結構的前提下,CSS3中提供了更多的風格、更強的效果。此外,較之前的Web排版,Web的開放字體格式(WOFF)也提供了更高的靈活性和控制性。
一、提升可用性和改進用戶的友好體驗;
二、有幾個新標籤,有助於開發人員定義重要內容;
三、可給站點帶來更多多媒體元素(視頻和音頻);
四、可很好的替代FLASH和Silverlight;
五、當涉及網站抓取和索引時,SEO很友好;
六、可大量應用於移動應用程序和遊戲;
七、可移植性好。
如下的 HTML 4.01 元素在HTML5中已經被刪除:
<acronym>
<applet>
<basefont>
<big>
<center>
<dir>
<font>
<frame>
<frameset>
<noframes>
<strike>
<article>標籤訂義外部的內容。好比來自一個外部的新聞提供者的一篇新的文章,或者來自 blog 的文本,或者是來自論壇的文本。
HTML5:<article></article>
HTML4:<div></div>
<aside>標籤訂義:側邊 article 之外的內容。aside 的內容應該與 article 的內容相關。
HTML5:<aside>Aside 的內容是獨立的內容,但應與文檔內容相關。</aside>
HTML4:<div>Aside 的內容是獨立的內容,但應與文檔內容相關。</div>
<audio> 標籤訂義聲音,好比音樂或其餘音頻流。
HTML5:<audio src="someaudio.wav">您的瀏覽器不支持 audio 標籤。</audio>
HTML4:<object type="application/ogg" data="someaudio.wav"><param name="src" value="someaudio.wav"></object>
<canvas> 標籤訂義圖形,好比圖表和其餘圖像。這個 HTML 元素是爲了客戶端矢量圖形而設計的。它本身沒有行爲,但卻把一個繪圖 API 展示給客戶端 JavaScript 以使腳本可以把想繪製的東西都繪製到一塊畫布上。
HTML5:<canvas id="myCanvas" width="200" height="200"></canvas>
HTML4:<object data="inc/hdr.svg" type="image/svg+xml" width="200" height="200"></object>
<command> 標籤訂義命令按鈕,好比單選按鈕、複選框或按鈕。
HTML5: <command onclick=cut()" label="cut">
HTML4: none
<datalist> 標籤訂義可選數據的列表。與 input 元素配合使用,就能夠製做出輸入值的下拉列表。
HTML5: <datalist></datalist>
HTML4: see combobox.
<details> 標籤訂義元素的細節,用戶可進行查看,或經過點擊進行隱藏。與 <legend> 一塊兒使用,來製做 detail 的標題。該標題對用戶是可見的,當在其上點擊時可打開或關閉 detail。
HTML5: <details></details>
HTML4: <dl style="display:hidden"></dl>
<embed> 標籤訂義嵌入的內容,好比插件。
HTML5: <embed src="horse.wav" />
HTML4: <object data="flash.swf" type="application/x-shockwave-flash"></object>
<figcaption> 標籤訂義 figure 元素的標題。」figcaption」 元素應該被置於 「figure」 元素的第一個或最後一個子元素的位置。
HTML5: <figure><figcaption>PRC</figcaption></figure>
HTML4: none
<figure> 標籤用於對元素進行組合。使用 <figcaption> 元素爲元素組添加標題。
HTML5: <figure><figcaption>PRC</figcaption><p>The People's Republic of China was born in 1949...</p></figure>
HTML4: <dl><h1>PRC</h1><p>The People's Republic of China was born in 1949...</p></dl>
<footer> 標籤訂義 section 或 document 的頁腳。典型地,它會包含創做者的姓名、文檔的創做日期以及/或者聯繫信息。
HTML5: <footer></footer>
HTML4: <div></div>
<header> 標籤訂義 section 或 document 的頁眉。
HTML5: <header></header>
HTML4: <div></div>
<hgroup> 標籤用於對網頁或區段(section)的標題進行組合。
HTML5: <hgroup></hgroup>
HTML4: <div></div>
<keygen> 標籤訂義生成密鑰。
HTML5: <keygen>
HTML4: none
<mark>主要用來在視覺上向用戶呈現那些須要突出的文字。<mark>標籤的一個比較典型的應用就是在搜索結果中向用戶高亮顯示搜索關鍵詞。
HTML5: <mark></mark>
HTML4: <span></span>
<meter> 標籤訂義度量衡。僅用於已知最大和最小值的度量。必須定義度量的範圍,既能夠在元素的文本中,也能夠在 min/max 屬性中定義。
HTML5: <meter></meter>
HTML4: none
<nav> 標籤訂義導航連接的部分。
HTML5: <nav></nav>
HTML4:<ul></ul>
<output> 標籤訂義不一樣類型的輸出,好比腳本的輸出。
HTML5: <output></output>
HTML4: <span></span>
<progress> 標籤運行中的進程。可使用 <progress> 標籤來顯示 JavaScript 中耗費時間的函數的進程。
HTML5: <progress></progress>
HTML4: none
<rp> 標籤在 ruby 註釋中使用,以定義不支持 ruby 元素的瀏覽器所顯示的內容。
HTML5: <ruby>漢 <rt><rp>(</rp>ㄏㄢˋ<rp>)</rp></rt></ruby>
HTML4: none
<rt> 標籤訂義字符(中文註音或字符)的解釋或發音。
HTML5: <ruby>漢 <rt> ㄏㄢˋ </rt></ruby>
HTML4: none
<ruby> 標籤訂義 ruby 註釋(中文註音或字符)。
HTML5: <ruby>漢 <rt><rp>(</rp>ㄏㄢˋ<rp>)</rp></rt></ruby>
HTML4: none
<section> 標籤訂義文檔中的節(section、區段)。好比章節、頁眉、頁腳或文檔中的其餘部分。
HTML5: <section></section>
HTML4: <div></div>
<source> 標籤爲媒介元素(好比 <video> 和 <audio>)定義媒介資源。
HTML5: <source>
HTML4: <param>
<summary> 標籤包含 details 元素的標題,」details」 元素用於描述有關文檔或文檔片斷的詳細信息。」summary」 元素應該是 「details」 元素的第一個子元素。
HTML5: <details><summary>HTML 5</summary>This document teaches you everything you have to learn about HTML 5.</details>
HTML4: none
<time> 標籤訂義日期或時間,或者二者。
HTML5: <time></time>
HTML4: <span></span>
<video> 標籤訂義視頻,好比電影片斷或其餘視頻流。HTML5: <video src="movie.ogg" controls="controls">您的瀏覽器不支持 video 標籤。</video>HTML4:<object type="video/ogg" data="movie.ogv"><param name="src" value="movie.ogv"></object>