怎么使用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属性上的。

以上是怎么使用H5的dataset的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!

本文标题:怎么使用H5的dataset
网址分享:https://www.cdcxhl.com/article38/gpejsp.html

成都网站建设公司_创新互联,为您提供营销型网站建设网站设计公司移动网站建设面包屑导航小程序开发静态网站

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

网站托管运营