如何使用H5的dataset

这次给大家带来如何使用H5的dataset,使用H5的dataset的注意事项有哪些,下面就是实战案例,一起来看一下。

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属性上的。

相信看了本文案例你已经掌握了方法,更多精彩请关注编程之家网其它相关文章

推荐阅读:

如何使用css3实现3d立体特效

使用DOM的一些小结

相关文章

HTML5和CSS3实现3D展示商品信息的代码
利用HTML5中的Canvas绘制笑脸的代码
Html5剪切板功能的实现
如何通过HTML5触摸事件实现移动端简易进度条
Html5移动端获奖无缝滚动动画实现
关于HTML5和CSS3实现机器猫的代码