pbootcms网站模板|日韩1区2区|织梦模板||网站源码|日韩1区2区|jquery建站特效-html5模板网

5個你不知道的HTML5的接口介紹_html5教程技巧

5個你不知道的HTML5的接口介紹_html5教程技巧HTML5中文學習網,是中國最大的HTML5中文門戶,為廣大HTML5愛好者提供各種HTML5資料,包括HTML5網站、HTML5資訊、HTML5應用、HTML5游戲、HTML5教程、
點評:盡管當前的主流瀏覽器已經實現了很多的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.></menuitem>
<menuitem label="騰訊微博" icon="http://mat1.gtimg.com/app/opent/images/wiki/resource/weiboicon32.png" onclick="window.location.></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="renfufei@qq.com">
<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("http://b" + cName + "http://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="http://mat1.gtimg.com/app/opent/images/wiki/resource/weiboicon32.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="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.></menuitem>
<menuitem label="騰訊微博" icon="http://mat1.gtimg.com/app/opent/images/wiki/resource/weiboicon32.png" onclick="window.location.></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>

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。
主站蜘蛛池模板: 安规_综合测试仪,电器安全性能综合测试仪,低压母线槽安规综合测试仪-青岛合众电子有限公司 | 安德建奇火花机-阿奇夏米尔慢走丝|高维|发那科-北京杰森柏汇 | 西安烟道厂家_排气道厂家_包立管厂家「陕西西安」推荐西安天宇烟道 | 不锈钢闸阀_球阀_蝶阀_止回阀_调节阀_截止阀-可拉伐阀门(上海)有限公司 | 广东恩亿梯电源有限公司【官网】_UPS不间断电源|EPS应急电源|模块化机房|电动汽车充电桩_UPS电源厂家(恩亿梯UPS电源,UPS不间断电源,不间断电源UPS) | SRRC认证_电磁兼容_EMC测试整改_FCC认证_SDOC认证-深圳市环测威检测技术有限公司 | 合肥卓创建筑装饰,专业办公室装饰、商业空间装修与设计。 | 液压油缸-液压缸厂家价格,液压站系统-山东国立液压制造有限公司 液压油缸生产厂家-山东液压站-济南捷兴液压机电设备有限公司 | 婚博会2024时间表_婚博会门票领取_婚博会地址-婚博会官网 | 振动筛-交叉筛-螺旋筛-滚轴筛-正弦筛-方形摇摆筛「新乡振动筛厂家」 | 【直乐】河北石家庄脊柱侧弯医院_治疗椎间盘突出哪家医院好_骨科脊柱外科专业医院_治疗抽动症/关节病骨伤权威医院|排行-直乐矫形中医医院 | 5nd音乐网|最新流行歌曲|MP3歌曲免费下载|好听的歌|音乐下载 免费听mp3音乐 | 辽宁资质代办_辽宁建筑资质办理_辽宁建筑资质延期升级_辽宁中杭资质代办 | 真空干燥烘箱_鼓风干燥箱 _高低温恒温恒湿试验箱_光照二氧化碳恒温培养箱-上海航佩仪器 | 深圳货架厂_仓库货架公司_重型仓储货架_线棒货架批发-深圳市诺普泰仓储设备有限公司 | pbootcms网站模板|织梦模板|网站源码|jquery建站特效-html5模板网 | 全自动五线打端沾锡机,全自动裁线剥皮双头沾锡机,全自动尼龙扎带机-东莞市海文能机械设备有限公司 | POS机办理_个人POS机免费领取 - 银联POS机申请首页 | 10吨无线拉力计-2吨拉力计价格-上海佳宜电子科技有限公司 | 一体化污水处理设备,一体化污水设备厂家-宜兴市福源水处理设备有限公司 | 金现代信息产业股份有限公司--数字化解决方案供应商 | 铝板冲孔网,不锈钢冲孔网,圆孔冲孔网板,鳄鱼嘴-鱼眼防滑板,盾构走道板-江拓数控冲孔网厂-河北江拓丝网有限公司 | 振动筛,震动筛,圆形振动筛,振动筛价格,振动筛厂家-新乡巨宝机电 蒸汽热收缩机_蒸汽发生器_塑封机_包膜机_封切收缩机_热收缩包装机_真空机_全自动打包机_捆扎机_封箱机-东莞市中堡智能科技有限公司 | 新中天检测有限公司青岛分公司-山东|菏泽|济南|潍坊|泰安防雷检测验收 | 冷却塔降噪隔音_冷却塔噪声治理_冷却塔噪音处理厂家-广东康明冷却塔降噪厂家 | 传爱自考网_传爱自学考试网 | 隐形纱窗|防护纱窗|金刚网防盗纱窗|韦柏纱窗|上海青木装潢制品有限公司|纱窗国标起草单位 | 专业的新乡振动筛厂家-振动筛品质保障-环保振动筛价格—新乡市德科筛分机械有限公司 | 国际高中-国际学校-一站式择校服务-远播国际教育 | 专注氟塑料泵_衬氟泵_磁力泵_卧龙泵阀_化工泵专业品牌 - 梭川泵阀 | 焊锡丝|焊锡条|无铅锡条|无铅锡丝|无铅焊锡线|低温锡膏-深圳市川崎锡业科技有限公司 | 武汉画册印刷厂家-企业画册印刷-画册设计印刷制作-宣传画册印刷公司 - 武汉泽雅印刷厂 | 伸缩器_伸缩接头_传力接头-巩义市润达管道设备制造有限公司 | 辽宁资质代办_辽宁建筑资质办理_辽宁建筑资质延期升级_辽宁中杭资质代办 | 工业设计,人工智能,体验式3D展示的智能技术交流服务平台-纳金网 J.S.Bach 圣巴赫_高端背景音乐系统_官网 | 铝箔-铝板-花纹铝板-铝型材-铝棒管-上海百亚金属材料有限公司 | 青岛代理记账_青岛李沧代理记账公司_青岛崂山代理记账一个月多少钱_青岛德辉财税事务所官网 | 复合土工膜厂家|hdpe防渗土工膜|复合防渗土工布|玻璃纤维|双向塑料土工格栅-安徽路建新材料有限公司 | 金属软管_不锈钢金属软管_巩义市润达管道设备制造有限公司 | 铝箔-铝板-花纹铝板-铝型材-铝棒管-上海百亚金属材料有限公司 | 二维运动混料机,加热型混料机,干粉混料机-南京腾阳干燥设备厂 |