管當前的主流浏覽器已經實現了很多的HTML5新特性,但是很多開發者根本就沒注意到這些更簡潔,也很有用的API,本系列文章介紹這些接口API,同時也希望能鼓勵更多開發者去探索那些還不廣為人知的API
原文地址: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類名)
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代碼。
代碼如下:
復制代碼
代碼如下:
<div class="hide">
<!-- contextmenu 指定了使用哪個上下文菜單。 -->
<!-- !!!不知道為什麼,我的浏覽器上這個配置不起作用。 -->
<section contextmenu="mymenu" style="min-height:100px;min-height:200px;background:#999;">
<h1>點擊此區域查看菜單</h1>
<!--
為了代碼結構的清晰,把menu元素放到了要使用的元素內部,其實你也可以放到外部的任何地方:
-->
<!-- 添加菜單,至於圖片圖標,請自己設置。add the menu -->
<menu type="context" id="mymenu">
<menuitem label="刷新頁面" onclick="window.location.reload();" icon="http://mat1.gtimg.com/app/opent/images/wiki/resource/weiboicon32.png"></menuitem>
<menu label="分享到..." icon="http://www.sinaimg.cn/blog/developer/wiki/32x32.png">
<menuitem label="新浪微博" icon="http://www.sinaimg.cn/blog/developer/wiki/32x32.png" onclick="window.location.href='http://www.weibo.com'"></menuitem>
<menuitem label="騰訊微博" icon="http://mat1.gtimg.com/app/opent/images/wiki/resource/weiboicon32.png" onclick="window.location.href='http://t.qq.com'"></menuitem></menuitem>
</menu>
</menu>
</section>
</div>
Element.dataset
數據集(dataset) API 允許開發者對DOM元素設置(set)和獲取(get) 以 data- 前綴開頭的屬性值。
代碼如下:
復制代碼
代碼如下:
<div id="intro" data-website="www.csdn.net" data-id="551996458" data-my-name="鐵錨" data-blog-url="http://blog.csdn.net/renfufei"></div>
復制代碼
代碼如下:
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);
};
沒有什麼好說的,和classList一樣,簡單卻實用。(想一想,是否改變了後台和前台JS的某些交互以及解耦?)
window.postMessage API
IE8 已經支持 postMessage API 好幾年了,此API允許window 和iframe 元素之間互相傳遞消息。
跨域支持哦。 代碼如下:
復制代碼
代碼如下:
// From window or frame on domain 1, send a message to the iframe which hosts another domain
var iframeWindow = document.getElementById("iframe").contentWindow;
iframeWindow.postMessage("Hello from the first window!");
// From inside the iframe on different host, receive message
window.addEventListener("message", function(event) {
// Make sure we trust the sending domain
if(event.origin == "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 元素能夠自動獲得焦點。
復制代碼
代碼如下:
<input autofocus="autofocus" />
<button autofocus="autofocus">Hi!</button>
<textarea autofocus="autofocus"></textarea>
autofocus 屬性主要用在簡單的輸入頁面,詳情請參考:autofocus 屬性
各浏覽器廠商對這些API的支持度各不相同,所以在使用之前最好檢測一下兼容性,花一些時間來閱讀上面所列出的API,您將會對他們了解和掌握更多。
部分的測試代碼如下:
復制代碼
代碼如下:
<!DOCTYPE html>
<html>
<head>
<title>5個你不知道的 HTML5 API接口演示 </title>
<meta name="Generator" content="EditPlus">
<meta name="Author" content="[email protected]">
<meta name="Description" content="original=http://davidwalsh.name/html5-apis">
<style>
.hide{ display:none}
.poplayer{ z-index:999; position:absolute;background-color:#fff; top:0px;left:0px;overflow: hidden;width:100%;height:100%;opacity:1;}
.close{ top:3px; right:10px;position:absolute;}
</style>
<script>
// 顯示警告信息
function warn(msg){
warn = warn || "一個未知警告!";
if(window.console){
console.warn(msg);
} else {
alert(msg);
}
};
// 使用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);
//