DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> HTML基礎知識 >> HTML5詳解 >> 5個你不知道的HTML5的接口介紹
5個你不知道的HTML5的接口介紹
編輯:HTML5詳解     
原文地址: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="/School/UploadFiles_7810/201603/20160310235924320.png"></menuitem> 
<menu label="分享到..." icon="/School/UploadFiles_7810/201603/20160310235924794.png"> 
<menuitem label="新浪微博" icon="/School/UploadFiles_7810/201603/20160310235924794.png" onclick="window.location.href='http://www.weibo.com'"></menuitem> 
<menuitem label="騰訊微博" icon="/School/UploadFiles_7810/201603/20160310235924320.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); 
// 
if(hasHide){ 
// 3. classList API 
// 移除hide類 
element.classList.remove(cName); 
} else { 
// 4. classList API 
// 添加hide類 
element.classList.add(cName); 

return true; 
}; 
// 使用className屬性(Dom元素,CSS類名) 
function toggleClassName(element,cName){ 
var className = element.className || ""; 
// 去掉首尾的空白 
cName = cName.replace(/^/s*|/s*$/g,""); 
// cName 中間如果含有空白字符,則失敗. 如果要好好處理,可以拆分為數組,單個處理 
var blankReg = //s+/; 
if(blankReg.test(cName)){ 
warn("'"+cName+"'中間含有空白字符"); 
return false; 

// 正則, /b 表示可見連續字符的邊界,可以這麼理解: 
// "hide2 hide hide myname" 那麼, 
// hide2 的前後各有一個虛擬的/b ,hide 前後也有, 
// 但是 hi 和 de之間則沒有。 
// g 表示單行全局 
//var rep = //bhide/b/g; 
var rep = new RegExp("//b" + cName + "//b", "g"); 
if(rep.test(className)){ 
className = className.replace(rep,""); 
} else { 
className += " "+cName; 

// 替換新className。 
element.className = className; 
return true; 
}; 
// 函數,切換(元素id,className) 
function toggleClass(elementId,cName){ 
// 獲取一個DOM元素 
var element = document.getElementById(elementId); 
// 如果不存在元素 
if(!element){ 
warn("id為"+elementId+"的元素不存在"); 
return false; 

if(!element.classList){ 
warn("id為"+elementId+"的元素不支持classList屬性,將使用其他手段來實現"); 
return toggleClassName(element,cName); 
} else { 
return toggleClassList(element,cName); 

}; 
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); 
}; 
// dom加載後 執行 
window.addEventListener("DOMContentLoaded", function() { 
var open = document.getElementById("open"); 
var close = document.getElementById("close"); 
open.addEventListener("click",function(){ 
// 
toggleClass("diary2","hide"); 
toggleClass("loading","hide"); 
}); 
close.addEventListener("click",function(){ 
// 
toggleClass("diary2","hide"); 
toggleClass("loading","hide"); 
}); 
// 
testDataset(); 
}, false); 
</script> 
</head> 
<body> 
<div> 
<div id="diary2" class="diary poplayer hide"> 
<a href="Javascript:void(0)" _fcksavedurl=""Javascript:void(0)"" id="close">關閉</a> 
<div id="loading" class="loading hide" style="z-index:1; position: absolute; left: 40%; top: 30%; width: 104px; height: 104px;opacity: 0.5;background: #000000;border: 0px solid #000000;border-radius: 10px;-webkit-border-radius: 10px;"> 
<img src="/School/UploadFiles_7810/201603/20160310235924320.png" alt="" 
style="position:absolute; left:26px; top:10px;width: 50px;height: 50px;border-radius: 10px;-webkit-border-radius: 10px;"> 
<div class="loadingtext" style="position:absolute;left: 12px;top: 76px;color: #ffffff;">正在加載中</div> 
</div> 
</div> 
<div> 
<a href="Javascript:void(0)" id="open">打開</a> 
</div> 
</div> 
<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="/School/UploadFiles_7810/201603/20160310235924320.png"></menuitem> 
<menu label="分享到..." icon="/School/UploadFiles_7810/201603/20160310235924794.png"> 
<menuitem label="新浪微博" icon="/School/UploadFiles_7810/201603/20160310235924794.png" onclick="window.location.href='http://www.weibo.com'"></menuitem> 
<menuitem label="騰訊微博" icon="/School/UploadFiles_7810/201603/20160310235924320.png" onclick="window.location.href='http://t.QQ.com'"></menuitem></menuitem> 
</menu> 
</menu> 
</section> 
</div> 
<div id="intro" data-website="www.csdn.net" data-id="551996458" data-my-name="鐵錨" data-blog-url="http://blog.csdn.Net/renfufei"></div> 
</body> 
</Html> 
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved