首页 web前端 H5教程 5个你不知道的HTML5的接口介绍_html5教程技巧

5个你不知道的HTML5的接口介绍_html5教程技巧

May 16, 2016 pm 03:48 PM

原文地址: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代码。
代码如下:

复制代码
代码如下:





点击此区域查看菜单














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);
};

没有什么好说的,和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 元素能够自动获得焦点。

复制代码
代码如下:





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>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", 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="position:absolute; left:26px; top:10px;width: 50px;height: 50px;border-radius: 10px;-webkit-border-radius: 10px;">
正在加载中









点击此区域查看菜单
















本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
2 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何使用视口元标记来控制移动设备上的页面缩放? 如何使用视口元标记来控制移动设备上的页面缩放? Mar 13, 2025 pm 08:00 PM

本文讨论了使用视口元标记来控制移动设备上的页面缩放,重点是宽度和初始尺度之类的设置,以获得最佳响应和性能。

如何将HTML5表单用于用户输入? 如何将HTML5表单用于用户输入? Mar 10, 2025 pm 02:59 PM

本文解释了如何创建和验证HTML5表格。 它详细介绍了&gt;元素,输入类型(文本,电子邮件,编号等)和属性(必需,模式,最小,最大)。 HTML5的优势比旧方法形成

如何将音频添加到我的HTML5网站上? 如何将音频添加到我的HTML5网站上? Mar 10, 2025 pm 03:01 PM

本文解释了如何使用&lt; audio&gt;元素,包括用于格式选择的最佳实践(MP3,OGG Vorbis),文件优化和JavaScript控件用于播放。 它强调使用多个音频f

如何使用地理位置API处理用户位置隐私和权限? 如何使用地理位置API处理用户位置隐私和权限? Mar 18, 2025 pm 02:16 PM

本文讨论了使用GeOlocation API管理用户位置隐私和权限,并强调要求权限,确保数据安全性并遵守隐私法律的最佳实践。

如何使用HTML5和JavaScript创建互动游戏? 如何使用HTML5和JavaScript创建互动游戏? Mar 10, 2025 pm 06:34 PM

本文使用JavaScript详细介绍了创建Interactive HTML5游戏。 它涵盖了游戏设计,HTML结构,CSS样式,JavaScript逻辑(包括事件处理和动画)以及音频集成。 必需的JavaScript库(Phaser,Pi

如何使用HTML5页面可见性API检测页面何时可见? 如何使用HTML5页面可见性API检测页面何时可见? Mar 13, 2025 pm 07:51 PM

本文讨论了使用HTML5页面可见性API来检测页面可见性,提高用户体验并优化资源使用情况。关键方面包括暂停媒体,减少CPU负载以及基于可见性变化管理分析。

如何将HTML5拖放API用于交互式用户界面? 如何将HTML5拖放API用于交互式用户界面? Mar 18, 2025 pm 02:17 PM

本文介绍了如何使用HTML5拖放API来创建交互式用户界面,详细介绍了使元素可拖动的步骤,处理关键事件并通过自定义反馈来增强用户体验。它还讨论了一个常见的陷阱

如何使用HTML5 Websockets API进行客户端和服务器之间的双向通信? 如何使用HTML5 Websockets API进行客户端和服务器之间的双向通信? Mar 12, 2025 pm 03:20 PM

本文解释了HTML5 Websockets API,用于实时双向客户服务器通信。 它详细详细介绍了客户端(JavaScript)和服务器端(Python/Flask)的实现,以应对可伸缩性,状态管理,一个挑战

See all articles