首頁 > web前端 > H5教程 > 5個你不知道的HTML5的介面介紹_html5教學技巧

5個你不知道的HTML5的介面介紹_html5教學技巧

WBOY
發布: 2016-05-16 15:48:58
原創
1968 人瀏覽過

原文網址:5 HTML5 APIs You Didn't Know Existed
原文日期: 2010年09月27日
翻譯日期:2013年8月7日
當人們看到或說出"HTML5"這個字的時候,估計至少有一半以上的人,會聯想到她既是一個性感而又充滿魅力的美女,同時也是一隻能把你搞得焦頭爛額的獨角獸,這能怪我們這些開發者嗎?
我們注意到那些基礎的Api停滯發展瞭如此漫長的時間(大概是1999-2009),以至於像"placeholder"這樣基礎的一個附加功能,也要花費我們不短的時間來處理。
儘管目前的主流瀏覽器已經實現了很多的HTML5新特性,但是很多開發者根本就沒注意到這些更簡潔,也很有用的API。
本系列文章介紹這些介面API,同時也希望能鼓勵更多開發者去探索那些還不廣為人知的API。
Element.classList
這個屬性已經發布了好幾年,透過classList,我們可以透過JavaScript來操縱底層css的class屬性.
程式碼如下:

複製程式碼
程式碼如下:

// 使用classList屬性(Dom元素,css類別名稱)

// 使用classList屬性(Dom元素,css類別名稱)
function toggleClassList(element,cName){
// 1. classList API
// 切換類別,有則移除,沒有則加
if(element.classList.toggle){
element .classList.toggle(cName);
return true;
}
// !!! 其實,本函數toggleClassList 如果支援的話,
// 那麼下面的程式碼就不會被執行,此處僅作示範,請靈活應用
// 2. classList API
// element 的class屬性是否包含hide 這個CSS類別
var hasHide = element.classList.contains(cName);
//
if(hasHide){
// 3. classList API
// 移除hide類別
element.classList.remove(cName);
} else {
// 4. classList API
// 新增hide類別
element.classList.add(cName);
}
return true;
};

ContextMenu API

測試chrome28不管用。 。 。
新的API,ContextMenu 是極好的介面: 此介面可讓你簡單地新增選單項目到瀏覽器的上下文選單(右鍵選單),而不是去覆寫瀏覽器的預設右鍵選單。
要注意的是,你最好採用js腳本來動態的建立選單contextmenu,這樣可以避免頁面停用JS腳本的情況 下出現多餘的HTML程式碼。
代碼如下:
複製代碼
代碼如下:






點擊此區域查看選單









menu>


Element.dataset
資料集(dataset) API 允許開發者對DOM元素設定(set)和取得(get) 以 data- 前綴開頭的屬性值。
代碼如下:

複製代碼
代碼如下:




複製代碼
代碼如下:


代碼如下:



代碼如下:



代碼如下:



代碼如下:



代碼如下:


代碼如下:


代碼如下:function testDataset(){
//
var intro = document.getElementById("intro");
// 注意這個不是id屬性哦,是data-id 的值
var id = intro.dataset.id;
// data-website var website = intro.dataset.website; // data-blog-url,駝峰命名法.. var blogUrl = intro.dataset.blogUrl; // data-my-name
var myName = intro.dataset.myName;
//
var msg = "qq:" id
",website :" website
",blogUrl:" blogUrl
",myName:" myName
;
//
warn(msg);
};

warn(msg);
};



沒有什麼好說的,跟classList一樣,簡單卻實用。 (想一想,是否改變了後台和前台JS的某些交互以及解耦?)
window.postMessage API
IE8 已經支援postMessage API 好幾年了,此API允許window和iframe 元素之間互相傳遞訊息。 跨域支援哦。 程式碼如下:


複製程式碼程式碼如下:
// Ffrom amedow on domain 1, send a message to the iframe which hosts another domain
var iframeWindow = document.getElementById("iframe").contentWindow;
iframeWindow.postMessage("Hello the fcontentWindow;
iframeWindow.postMessage("Hello the fir); >// From inside the iframe on different host, receive message
window.addEventListener("message", function(event) {
// Make sure we trust the sending domain
if(event.ori = = "http://davidwalsh.name") {
// Log out the message
console.log(event.data);
// Send a message back
event.source.postMessage ("Hello back!");
}
]); // message 只允許string 類型的數據,然而您可以使用JSON.stringify 以及JSON.parse 傳遞更多有意義的訊息。
autofocus Attribute
autofocus 屬性確保頁面載入後,給定的 BUTTON,INPUT或 TEXTAREA 元素能夠自動獲得焦點。 複製程式碼程式碼如下: 程式碼如下: Hi! autofocus 屬性主要用在簡單的輸入頁,詳情請參考:autofocus 屬性各瀏覽器廠商對這些API的支持度各不相同,所以在使用之前最好檢測一下兼容性,花一些時間來閱讀上面所列出的API,您將會對他們了解並掌握更多。 部分的測試程式碼如下: 複製程式碼程式碼如下:




5個你不知道的HTML5 API介面示範




<script> <br />// 顯示警告訊息<br />function warn(msg){ <br />warn = warn || "一個未知警告!"; <br />if(window.console){ <br /> console.warn(msg); <br />} else { <br />alert(msg); <br />} <br />}; <br />// 使用classList屬性(Dom元素,css類別) <br />function toggleClassList(element,cName){ <br />// 1. classList API <br />// 切換類別,有則移除,沒有則加入<br />if(element.classList.toggle){ <br />element.classList .toggle(cName); <br />return true; <br />} <br />// !!! 其實,本函數toggleClassList 如果支援的話, <br />// 那麼下面的程式碼就不會被執行,此處僅供示範,請靈活應用<br />// 2. classList API <br />// element 的class屬性是否包含hide 這個CSS類別<br />var hasHide = element.classList.contains(cName); <br />/ / <br />if(hasHide){ <br />// 3. classList API <br />// 移除hide類別<br />element.classList.remove(cName); <br />} else { <br />// 4. classList API <br />// 新增hide類別<br />element.classList.add(cName); <br />} <br />return true; <br />}; <br />// 使用className屬性(Dom元素,css類別名稱) <br />function toggleClassName(element,cName){ <br />var className = element.className || ""; <br />// 去掉首尾的空白<br />cName = cName.replace(/^ s*|s*$/g,""); <br />// cName 中間如果含有空白字符,則失敗. 如果要好好處理,可以拆分為數組,單個處理<br />var blankReg = /s / ; <br />if(blankReg.test(cName)){ <br />warn("'" cName "'中間含有空白字元"); <br />return false; <br />} <br />// 正規, b表示可見連續字元的邊界,可以這麼理解: <br />// "hide2 hide hide myname" 那麼, <br />// hide2 的前後各有一個虛擬的b ,hide 前後也有, <br />// 但是hi和de之間則沒有。 <br />// g 表示單行全域<br />//var rep = /bhideb/g; <br />var rep = new RegExp("\b" cName "\b", "g"); <br />if (rep.test(className)){ <br />className = className.replace(rep,""); <br />} else { <br />className = " " cName; <br />} <br />// 取代新className。 <br />element.className = className; <br />return true; <br />}; <br />// 函數,切換(元素id,className) <br />function toggleClass(elementId,cName){ <br />//取得一個DOM元素<br />var element = document.getElementById(elementId); <br />// 如果不存在元素<br />if(!element){ <br />warn("id為" elementId "的元素不存在"); <br />return false; <br />} <br />if(!element.classList){ <br />warn("id為" elementId "的元素不支援classList屬性,將使用其他手段來實作") ; <br />return toggleClassName(element,cName); <br />} else { <br />return toggleClassList(element,cName); <br />} <br />}; <br />function testDataset(>} <br />}; <br />function testDataset(){ <br /> / <br />var intro = document.getElementById("intro"); <br />// 注意這個不是id屬性哦,是data-id 的值<br />var id = intro.dataset.id; <br />/ / data-website <br />var website = intro.dataset.website; <br />// data-blog-url,駝峰命名法.. <br />var blogUrl = intro.dataset.blogUrl; <br />// data -my-name <br />var myName = intro.dataset.myName; <br />// <br />var msg = "qq:" id <br /> ",website:" website <br /> ",blogUrl:" blogUrl <br /> ",myName:" myName <br />; <br />// <br />warn(msg); <br />}; <br />// dom載入後執行<br />window.addEventListener("DOMContentLoaded"DOMContentLoaded" , function() { <br />var open = document.getElementById("open"); <br />var close = document.getElementById("close"); <br />open.addEventListener("click",function(){ <br />// <br />toggleClass("diary2","hide"); <br />toggleClass("loading","hide"); <br />}); <br />close.addEventListener("click", function(){ <br />// <br />toggleClass("diary2","hide"); <br />toggleClass("loading","hide"); <br />}); <br />// <br />testDataset(); <br />}, false); <br /></script>



關閉

style="max-width:90%">
正在載入中

div>







點擊此區域查看選單









menu>






相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板