前言
什么是HTML5:HTML5 是下一代的HTML,將成為 HTML、XHTML 以及 HTML DOM 的新標準。今天來談談前端面試中基本上每次一面的時候都會被問到的一個問題,那就是html5的新特性。這個是學習前端必須掌握的基礎知識。
新增的元素
html5新增了一些語義化更好的標簽元素。
結構元素
其他元素
廢除的元素
html5中廢除了一些純表現的元素,只有部分瀏覽器支持的元素還有一些會對可用性產生負面影響的元素。
純表現元素
純表現的元素就是那些可以用css替代的元素。basefont、big、center、font、s、strike、tt、u這些元素,他們的功能都是純粹為頁面展示服務的,html5提倡把頁面展示性功能放在css樣式表中統一處理,所以將這些元素廢除,用css樣式進行替代。
對可用性產生負面影響的元素
對于frameset元素、frame元素與noframes元素,由于frame框架對網頁可用性存在負面影響,在html5中已不支持frame框架,只支持iframe框架,html5中同時將frameset、frame和noframes這三個元素廢除。
只有部分瀏覽器支持的元素
對于applet、bgsound、blink、marquee等元素,由于只有部分瀏覽器支持,特別是bgsound元素以及marquee元素,只被IE支持,所以在html5中被廢除。其中applet元素可由embed元素或object元素替代,bgsound元素可由audio元素替代,marquee可以由javascript編程的方式替代。
新增的API
Canvas API
上文提到的canvas元素可以為頁面提供一塊畫布來展示圖形。結合Canvas API,就可以在這塊畫布上動態生成和展示各種圖形、圖表、圖像以及動畫了。Canvas本質上是位圖畫布,不可縮放,繪制出來的對象不屬于頁面DOM結構或者任何命名空間。不需要將每個圖元當做對象存儲,執行性能非常好。
利用Canvas API進行繪圖,首先要獲取canvas元素的上下文,然后用該上下文中封裝的各種繪圖功能進行繪圖。
<canvas id="canvas">替代內容</canvas><script> var canvas = document.getElementById('canvas'); var context =canvas.getContext("2d"); // 獲取上下文 //設置純色 context.fillStyle = "red"; context.strokeStyle = "blue"; // 實踐表明在不設置fillStyle下的默認fillStyle為black context.fillRect(0, 0, 100, 100); // 實踐表明在不設置strokeStyle下的默認strokeStyle為black context.strokeRect(120, 0, 100, 100);</script>
SVG
SVG是html5的另一項圖形功能,它是一種標準的矢量圖形,是一種文件格式,有自己的API。html5引入了內聯SVG,使得SVG元素可以直接出現在html標記中。
<svg height=100 width=100><circle cx=50 cy=50 r=50 /></svg>
音頻和視頻
audio和video元素的出現讓html5的媒體應用多了新選擇,開發人員不必使用插件就能播放音頻和視頻。對于這兩個元素,html5規范提供了通用、完整、可腳本化控制的API。
html5規范出來之前,在頁面中播放視頻的典型方式是使用Flash、QuickTime或者Windows Media插件往html中嵌入音頻視頻,相對這種方式,使用html5的媒體標簽有兩大好處。
<video src="video.webm" controls> <object data="videoplayer.swf" type="application/x-shockwave-flash"> <param name="movie" value="video.swf" /> </object> Your browser does not support HTML5 video.</video>
瀏覽器支持性檢測
瀏覽器檢測是否支持audio元素或者video元素最簡單的方式是用腳本動態創建它,然后檢測特定函數是否存在。
var hasVideo = !!(document.createElement('video').canPlayType);
Geolocation API
html5的Geolocation API(地理定位API),可以請求用戶共享他們的位置。使用方法非常簡單,如果用戶同意,瀏覽器就會返回位置信息,該位置信息是通過支持html5地理定位功能的底層設備(如筆記本電腦或手機)提供給瀏覽器的。位置信息由緯度、經度坐標和一些其他元數據組成。
位置信息從何而來
Geolocation API不指定設備使用哪種底層技術來定位應用程序的用戶。相反,它只是用于檢索位置信息的API,而且通過該API檢索到的數據只具有某種程度的準確性,并不能保證設備返回的位置是精確的。設備可以使用下列數據源:
使用方法
// 一次更新navigator.geolocation.getCurrentPosition(updateLocation, handleLocationEror);function updateLocation(position) { var latitude = position.coords.latitude; // 緯度 var longitude = position.coords.longitude; // 經度 var accuracy = position.coords.accuracy; // 準確度 var timestamp = position.coords.timestamp; // 時間戳}// 錯誤處理函數function handleLocationEror(error) { ....}// 重復更新navigator.geolocation.watchPosition(updateLocation, handleLocationEror);// 不再接受位置更新navigator.geolocation.clearWatch(watchId);
Communication API
跨文檔消息傳遞
出于安全方面的考慮,運行在同一瀏覽器中的框架、標簽頁、窗口間的通信一直都受到了嚴格的限制。然而,現實中存在一些合理的讓不同站點的內容能在瀏覽器內進行交互的需求。這種情形下,如果瀏覽器內部能提供直接的通信機制,就能更好地組織這些應用。
html5中引入了一種新功能,跨文檔消息通信,可以確保iframe、標簽頁、窗口間安全地進行跨源通信。postMessage API為發送消息的標準方式,發送消息非常簡單:
window.postMessage('Hello, world', 'http://www.example.com/');
接收消息時,僅需在頁面中增加一個事件處理函數。當某個消息到達時,通過檢查消息的來源來決定是否對這條消息進行處理。
window.addEventListener("message", messageHandler, true);function messageHandler(e) { switch(e.origin) { case "friend.example.com": // 處理消息 processMessage(e.data); break; default: // 消息來源無法識別 // 消息被忽略 }}
消息事件是一個擁有data(數據)和origin(源)屬性的DOM事件。data屬性是發送方傳遞的實際消息,而origin屬性是發送來源。
XMLHttpRequest Level2
XMLHttpRequest API使得Ajax技術成為可能,作為XMLHttpRequest的改進版,XMLHttpRequest Level2在功能上有了很大的改進。主要兩個方面:
跨源XMLHttpRequest
過去,XMLHttpRequest僅限于同源通信,XMLHttpRequest Level2通過CORS實現了跨源XMLHttpRequest??缭碒TTP請求包含一個Origin頭部,它為服務器提供HTTP請求的源信息。
WebSockets API
WebSockets是html5中最強大的通信功能,它定義了一個全雙工通信信道,僅通過Web上的一個Socket即可進行通信。
WebSockets握手
為了建立WebSockets通信,客戶端和服務器在初始握手時,將HTTP協議升級到WebSocket協議。一旦連接建立成功,就可以在全雙工模式下在客戶端和服務器之間來回傳遞WebSocket消息。
WebSockets接口
除了對WebSockets協議定義外,該規范還同時定義了用于JavaScript應用程序的WebSocket接口。WebSockets接口的使用很簡單。要連接遠程主機,只需要新建一個WebSocket實例,提供希望連接的對端URL。
Forms API
新表單元素
未來的表單元素
新的表單特性和函數
placeholder
當用戶還沒輸入值的時候,輸入型控件可以通過placeholder特性向用戶顯示描述性說明或者提示信息。
<input name="name" placeholder="First and last name">
autocomplete
瀏覽器通過autocomplete特性能夠知曉是否應該保存輸入值以備將來使用。
autofocus
通過autofocus特性可以指定某個表單元素獲得輸入焦點,每個頁面上只允許出現一個autofocus特性,如果設置了多個,則相當于未指定此行為。
spellcheck
可對帶有文本內容的輸入控件和textarea空間控制spellcheck屬性。設置完后,會詢問瀏覽器是否應該給出拼寫檢查結果反饋。spellcheck屬性需要賦值。
list特性和datalist元素
通過組合使用list特性和datalist元素,開發人員能夠為某個輸入型控件構造一張選值列表。
<datalist id="contactList"> <option value="a@qq.com"></option> <option value="b@qq.com"></option></datalist><input type="email" id="contatcs" list="contactList">
min和max
通過設置min和max特性,可以將range輸入框的數值輸入范圍限定在最低值和最高值之間??梢灾辉O置一個,也可以兩個都設置,也可以都不設置。
step
對于輸入型控件,設置其step特性能夠指定輸入值遞增或者遞減的粒度。
required
一旦為某輸入型控件設置了required特性,那么此項必填,否則無法提交表單。
拖放API
draggable屬性
如果網頁元素的draggable元素為true,這個元素就是可以拖動的。
<div draggable="true">Draggable Div</div>
拖放事件
拖動過程會觸發很多事件,主要有下面這些:
draggableElement.addEventListener('dragstart', function(e) { console.log('拖動開始!');});
dataTransfer對象
拖動過程中,回調函數接受的事件參數,有一個dataTransfer屬性,指向一個對象,包含與拖動相關的各種信息。
draggableElement.addEventListener('dragstart', function(event) { event.dataTransfer.setData('text', 'Hello World!');});
dataTransfer對象的屬性有:
dataTransfer對象的方法有:
Web Workers API
Javascript是單線程的。因此,持續時間較長的計算,回阻塞UI線程,進而導致無法在文本框中填入文本,單擊按鈕等,并且在大多數瀏覽器中,除非控制權返回,否則無法打開新的標簽頁。該問題的解決方案是Web Workers,可以讓Web應用程序具備后臺處理能力,對多線程的支持性非常好。
但是在Web Workers中執行的腳本不能訪問該頁面的window對象,也就是Web Workers不能直接訪問Web頁面和DOM API。雖然Web Workers不會導致瀏覽器UI停止響應,但是仍然會消耗CPU周期,導致系統反應速度變慢。
Web Storage API
Web Storage是html5引入的一個非常重要的功能,可以在客戶端本地存儲數據,類似html4的cookie,但可實現功能要比cookie強大的多。
sessionStorage
sessionStorage將數據保存在session中,瀏覽器關閉數據就消失。
localStorage
localStorage則一直將數據保存在客戶端本地,除非手動刪除,否則一直保存。
不管是sessionStorage,還是localStorage,可使用的API相同,常用的有如下幾個(以localStorage為例):
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。
新聞熱點
疑難解答