如何使用H5的dataset


本文摘自PHP中文网,作者php中世界最好的语言,侵删。

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

HTML5标准允许你在普通的元素标签里,嵌入类似data-*的属性,来实现一些简单数据的存取。它的数量不受限制,并且也能由javascript动态修改,也支持CSS选择器进行样式设置。这使得data属性特别灵活,也非常强大。有了这样的属性我们能够更加有序直观的进行数据预设或存储。当然,任何的标签元素里面可以随意的加上任何自定义属性,也可以获取他们的值,但没有这个来的灵活。我们先来看一下随意的属性存储数据吧。

1.利用dom节点对象的setAttribute和getAttribute

例子:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

<!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-*。比如刚才例子,想给音乐

注入更多关于这首歌数据,可以这样写:

1

2

3

4

5

6

7

8

<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字段,并以对象的方式,方便存取和遍历。例如,对于上面的例子,可以运行 :

1

2

3

4

5

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

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

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

使用DOM的一些小结

以上就是如何使用H5的dataset的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

h5页面如何调用摄像头代码分享

h5怎样用绘制五角星

h5新标签浏览器的兼容问题

html5游戏框架cngamejs开发实录-碰撞检测模块篇

h5中history模式的使用详解

详解html5图片上传支持图片预览压缩及进度显示兼容ie6及标准浏览器

如何区别html5离线存储和本地缓存实例详解

h5 语义化标签介绍

html5画布如何设置字体颜色?(代码示例)

html5实现的在线视频播放

更多相关阅读请进入《dataset》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...