如何使用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的详细内容,更多请关注其它相关文章!
上一篇: JS常用的消息框有哪些
下一篇: 评曾老“黄帝的人生智慧”
推荐阅读
-
使用 doctrine orm 如何在程序逻辑上实现在一张表完成两个外键的设置(或则说一个实体完成两个多对一的关系)?
-
如何使用php绘制在图片上的正余弦曲线_PHP
-
如何使用css3实现一个类在线直播的队列动画的示例代码
-
Node.js中关于多进程模块Cluster的详细介绍以及如何使用
-
如何解决Win1021H1内存占用太高 最新电脑内存使用率太高的解决教程
-
ASP.NET使用Ajax如何返回Json对象的示例方法介绍
-
[PHP]如何在百度(BAE)和新浪(SAE)的云平台使用PHP连接MySQL并返
-
巧学巧用:如何使用PHP中的字符串函数_PHP教程
-
【qml】qml中连接C++中的信号时如何使用参数?
-
使用unset()时出现的异常如何解决