HTML5新特性之dataset实例
2017-04-01 07:25
489 查看
HTML5标准允许你在普通的元素标签里,嵌入类似data-*的属性,来实现一些简单数据的存取。它的数量不受限制,并且也能由javascript动态修改,也支持CSS选择器进行样式设置。这使得data属性特别灵活,也非常强大。有了这样的属性我们能够更加有序直观的进行数据预设或存储。当然,任何的标签元素里面可以随意的加上任何自定义属性,也可以获取他们的值,但没有这个来的灵活。我们先来看一下随意的属性存储数据吧。
1.利用dom节点对象的setAttribute和getAttribute
例子:
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="Generator" content="EditPlus®">
<meta name="Author" content="">
<meta name="Keywords" content="">
<meta name="Description" content="">
<title>Document</title>
</head>
<body>
<span id="music" mtitle="yestoday once more">昨日重现</span>
<script type="text/javascript">
var mdoc=document.getElementById('music');
alert(mdoc.getAttribute('mtitle'));
</script>
</body>
</html>
运行这段代码,页面上可以获取mtitle对应的值。这样写虽然可以,但是想要预置更多的信息,应该采用一个语义属性data-*。比如刚才例子,想给音乐
注入更多关于这首歌数据,可以这样写:
<span id="music-latch" class="musique"
data-date="2013"
data-genre="Electronic"
data-album="Settle (Deluxe)"
data-artist="Disclosure"
data-composer="Howard Lawrence & Guy Lawrence">
Latch (feat. Sam Smith)
</span>
访问属性还是可以采用第一种方式:var album = document.getElementById("music-latch").getAttribute("data-album");
console.log(album);
但是这种方法比较低端,如果遇到多个data-*自定义字段,想要一次全部获取所有的data属性并包装成对象的话,还必须做一个循环,很麻烦。不过我们还有Dataset API可用。
2. 利用 dataset API 存取 dataset
通过.dataset API,我们可以更方便的获取元素的所有data字段,并以对象的方式,方便存取和遍历。例如,对于上面的例子,可以运行 :
<script type="text/javascript">
var mdoc=document.getElementById('music-latch');
var ds=mdoc.dataset;
alert(ds.date+'--'+ds.album);
</script>
这时候我们在访问data时,就不需要"data-"关键词了,直接利用.dataset.name就可以访问到。这比上面的方法更方便。所做出的任何更改,都是可以实时反映到元素data属性上的。
ok,收笔。
1.利用dom节点对象的setAttribute和getAttribute
例子:
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="Generator" content="EditPlus®">
<meta name="Author" content="">
<meta name="Keywords" content="">
<meta name="Description" content="">
<title>Document</title>
</head>
<body>
<span id="music" mtitle="yestoday once more">昨日重现</span>
<script type="text/javascript">
var mdoc=document.getElementById('music');
alert(mdoc.getAttribute('mtitle'));
</script>
</body>
</html>
运行这段代码,页面上可以获取mtitle对应的值。这样写虽然可以,但是想要预置更多的信息,应该采用一个语义属性data-*。比如刚才例子,想给音乐
注入更多关于这首歌数据,可以这样写:
<span id="music-latch" class="musique"
data-date="2013"
data-genre="Electronic"
data-album="Settle (Deluxe)"
data-artist="Disclosure"
data-composer="Howard Lawrence & Guy Lawrence">
Latch (feat. Sam Smith)
</span>
访问属性还是可以采用第一种方式:var album = document.getElementById("music-latch").getAttribute("data-album");
console.log(album);
但是这种方法比较低端,如果遇到多个data-*自定义字段,想要一次全部获取所有的data属性并包装成对象的话,还必须做一个循环,很麻烦。不过我们还有Dataset API可用。
2. 利用 dataset API 存取 dataset
通过.dataset API,我们可以更方便的获取元素的所有data字段,并以对象的方式,方便存取和遍历。例如,对于上面的例子,可以运行 :
<script type="text/javascript">
var mdoc=document.getElementById('music-latch');
var ds=mdoc.dataset;
alert(ds.date+'--'+ds.album);
</script>
这时候我们在访问data时,就不需要"data-"关键词了,直接利用.dataset.name就可以访问到。这比上面的方法更方便。所做出的任何更改,都是可以实时反映到元素data属性上的。
ok,收笔。
相关文章推荐
- HTML5新特性之WebSocket实例(可下载)
- HTML5新特性之CSS+HTML5实例
- DOMStringMap类型——HTML5新特性dataset的类型哦
- HTML5新特性: 自定义属性前缀data-以及dataset的使用
- HTML5新特性之CSS+HTML5实例
- 关于HTML5你必须知道的28个新特性,新技巧以及新技术
- 详解HTML5新特性(转自:英特尔开发人员专区)
- HTML5是什么?新特性和新功能介绍
- HTML5高阶实例之video
- jQuery中使用data()方法读取HTML5自定义属性data-*实例
- HTML5动画实例
- HTML5新特性之Communication
- 28个你必须知道的HTML5的新特性,技巧以及技术
- JavaScript+html5 canvas绘制缤纷多彩的三角形效果完整实例
- HTML5开发实例
- JavaScript+html5 canvas绘制的圆弧荡秋千效果完整实例
- 【HTML5入门教程一】什么是HTML5 有何新特性?分享经验
- HTML5 & CSS3的新交互特性
- HTML5新特性详解
- html5之Canvas坐标变换应用-时钟实例