中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

5個你不知道的HTML5的接口介紹
來源:易賢網 閱讀:1743 次 日期:2016-07-13 13:37:45
溫馨提示:易賢網小編為您整理了“5個你不知道的HTML5的接口介紹”,方便廣大網友查閱!

當人們看到或者說出"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("\\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="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>

更多信息請查看網頁制作
易賢網手機網站地址:5個你不知道的HTML5的接口介紹
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
欧美另类亚洲| 麻豆久久精品| 欧美jizzhd精品欧美喷水| 国产亚洲福利| 欧美日本在线看| 欧美精品1区2区| 欧美成在线视频| 欧美不卡三区| 欧美色欧美亚洲另类二区| 久久影院午夜论| 欧美国产精品中文字幕| 免费一级欧美在线大片| 欧美成人亚洲成人日韩成人| 亚洲欧美国产毛片在线| 午夜一区二区三区不卡视频| 久久国产精品亚洲va麻豆| 免费一区二区三区| 欧美精品一区在线| 欧美午夜电影一区| 国产欧美 在线欧美| 伊人久久大香线蕉综合热线| 亚洲最新在线视频| 久久噜噜噜精品国产亚洲综合| 猛干欧美女孩| 国产精品久久亚洲7777| 一区福利视频| 9i看片成人免费高清| 欧美在线视频二区| 你懂的视频欧美| 国产精品久久久久久久久免费 | 欧美精品一区二区三区蜜桃| 欧美色网一区二区| 伊人久久亚洲热| 午夜视频一区在线观看| 欧美午夜视频网站| 亚洲日本va午夜在线电影| 性做久久久久久久免费看| 国产精品激情av在线播放| 国产一区二区电影在线观看 | 欧美日本一区二区三区| 欧美性一区二区| 国产精品亚洲人在线观看| 亚洲国产一区二区在线| 免费亚洲视频| 在线日韩成人| 蜜桃伊人久久| 亚洲高清av在线| 欧美不卡一区| 亚洲天堂男人| 国产婷婷色一区二区三区| 欧美综合激情网| 亚洲精品免费在线播放| 欧美日韩日日夜夜| 久久精品视频亚洲| 在线欧美不卡| 欧美手机在线| 亚洲一区二区三区高清| 国产精品一卡二| 久久综合色影院| 中文av字幕一区| 亚洲大片免费看| 欧美性做爰猛烈叫床潮| 美女999久久久精品视频| 一区二区免费在线观看| 在线成人小视频| 国产精品欧美一区喷水| 久久亚洲影院| 亚洲欧美激情一区二区| 亚洲国产三级| 韩国av一区二区三区四区| 欧美日韩三级电影在线| 午夜精品区一区二区三| 日韩视频在线播放| 亚洲人成网站999久久久综合| 国产精品入口麻豆原神| 欧美精品一区二区精品网| 欧美在线播放高清精品| 亚洲欧美日韩国产一区| 日韩午夜免费| 亚洲网站视频福利| 亚洲一区视频在线| 夜夜躁日日躁狠狠久久88av| 日韩亚洲欧美一区二区三区| 亚洲第一在线综合网站| 国产欧美一区二区三区另类精品| 欧美激情第4页| 欧美三级午夜理伦三级中文幕| 欧美好骚综合网| 欧美特黄a级高清免费大片a级| 欧美美女bb生活片| 国产精品分类| 好吊一区二区三区| 樱花yy私人影院亚洲| 在线观看亚洲精品| 99re66热这里只有精品4| 亚洲免费婷婷| 亚洲欧美在线看| 欧美三级韩国三级日本三斤| 欧美精品日韩精品| 久久在线视频在线| 欧美日精品一区视频| 国产欧美精品va在线观看| 一区二区在线视频播放| 亚洲区一区二区三区| 午夜亚洲性色视频| 欧美日韩免费精品| 国产婷婷精品| 欧美亚洲自偷自偷| 欧美高清视频在线播放| 国产午夜精品一区二区三区欧美| 蜜臀a∨国产成人精品| 国产欧美精品| 欧美成人一品| 在线观看中文字幕亚洲| 国产精品国产精品国产专区不蜜| 欧美色欧美亚洲高清在线视频| 国产精品久久久久aaaa九色| 一区精品在线播放| 亚洲视频在线观看一区| 欧美日韩国产成人在线免费| 国产尤物精品| 久久综合狠狠| 禁久久精品乱码| 激情五月***国产精品| 亚洲综合精品| 国产精品久久久久久一区二区三区 | 国模大胆一区二区三区| 亚洲精品国产精品国自产在线| 久久夜色精品亚洲噜噜国产mv| 国产亚洲一级| 亚洲欧美成人网| 国产日韩精品视频一区| 一区二区三区欧美视频| 国产精品户外野外| av成人激情| 在线看欧美日韩| 午夜精品福利在线| 欧美日本乱大交xxxxx| 欧美午夜视频网站| 亚洲欧美日韩综合国产aⅴ| 精品成人一区二区三区| 欧美96在线丨欧| 亚洲欧洲在线播放| 国产精品超碰97尤物18| 久久久精彩视频| 亚洲午夜在线观看视频在线| 国产精品一区二区你懂的| 亚洲欧美精品suv| 亚洲免费高清| 好吊妞**欧美| 国产亚洲美州欧州综合国| 免费高清在线一区| 欧美尤物一区| 中国日韩欧美久久久久久久久| 在线欧美影院| 影音先锋亚洲视频| 欧美日韩国产黄| 欧美在线播放视频| 亚洲综合精品| 午夜精品久久久久久久蜜桃app | 欧美高清在线视频观看不卡| 亚洲国产婷婷香蕉久久久久久| 国内精品久久久久影院色| 国产精品美女黄网| 国产精品一区二区你懂得| 国产精品拍天天在线| 老鸭窝亚洲一区二区三区| 免费成人性网站| 亚洲人体影院| 久久久久一区二区三区四区| 精品96久久久久久中文字幕无| 好看的日韩av电影| 亚洲精品美女在线观看| 亚洲一区二区三区午夜| 久久综合狠狠综合久久综青草| 欧美色区777第一页| 欧美精品网站| 亚洲国产精品欧美一二99| 免费观看国产成人| 亚洲承认在线| 一区二区高清视频在线观看| 久久久91精品国产| 国产精品私拍pans大尺度在线| 亚洲成人在线视频网站| 欧美一区永久视频免费观看| 欧美日韩国产a| 一本色道婷婷久久欧美| 久久视频免费观看| 国产日韩av一区二区| 亚洲影音先锋| 欧美全黄视频| 亚洲一区二区三区免费视频| 欧美日韩情趣电影| 一区二区激情| 国产精品网站在线| 久久九九免费视频| 欲香欲色天天天综合和网| 午夜国产不卡在线观看视频| 国产亚洲欧美一区二区三区| 午夜久久黄色|