HTML5自定义属性对象Dataset简介

本文介绍了HTML5中的Dataset特性,这是一种用于获取自定义属性值的新方式。通过Dataset,开发者可以直接访问带有data-前缀的属性值,简化了代码并提高了可读性。此外,还讨论了Dataset与getAttribute的区别、在CSS中的应用及一些实用示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


======================================================
注:本文源代码点此下载
======================================================

一、html5 自定义属性介绍

之前翻译的“你必须知道的28个html5特征、窍门和技术”一文中对于html5中自定义合法属性data-已经做过些介绍,就是在html5中我们可以使用data-前缀设置我们需要的自定义属性,来进行一些数据的存放,例如我们要在一个文字按钮上存放相对应的id:

测试

这里的data-前缀就被称为data属性,其可以通过脚本进行定义,也可以应用css属性选择器进行样式设置。数量不受限制,在控制和渲染数据的时候提供了非常强大的控制。

二、dataset基础

下面是元素应用data属性的一个例子:

data-drink="coffee"

data-food="sushi"

data-meal="lunch">¥20.12

要想获取某个属性的值,可以像下面这样使用dataset对象:

var expenseday2 = document.getelementbyid('day2-meal-expense');

var typeofdrink = expenseday2.dataset.drink;

关于这个基本使用,我做了个demo,您可以狠狠地点击这里:dataset基本使用实例demo

点击demo页面的按钮做测试,如果浏览器不支持dataset,例如firefox 4,则弹出的结果就会类似下面:

如果支持,例如chrome 11浏览器,则弹出的结果就是:

需要注意的是带连字符连接的名称在使用的时候需要命名驼峰化,即大小写组合书写,这与应用元素的style对象类似,dom.style.bordercolor。例如,假设上面的例子中现在有如下data属性,data-meal-time,则我们要获取相应的值可以使用:

expenseday2.dataset.mealtime

data属性基本上所有的浏览器都是支持的,但是dataset对象就属于新贵,目前仅在opera 11.1+, chrome 9+下可以通过javascript,使用dataset访问你自定义的data属性。至于其他浏览器,firefox 6+(未出)以及safari 6+(未出)会支持dataset对象,至于ie浏览器,目前看来还是遥遥无期的趋势。具体的些兼容性数据,您可以点击这里访问。

如果你看到这段文字,说明您正使用rss阅读或转自《一棵树-博客园》,原文地址:http://www.cnblogs.com/atree/archive/2011/08/24/html5-dataset.html

三、我们为何需要dataset

如果使用传统的方法获取属性值应该会类似下面:

var typeofdrink = document.getelementbyid('day2-meal-expense').getattribute('data-drink');

现在,假设我们要获得多个自定义的属性值,得,折腾的事情就来了,我们可能要采用类似下面的n行代码实现了:

var attrs = expenseday2.attributes,

expense = {}, i, j;

for (i = 0, j = attrs.length; i

而使用dataset属性,我们根本不需要任何循环去获取你想要的那个值,直接秒杀:

expense = document.getelementbyid('day2-meal-expense').dataset;

dataset并不是典型意义上的javascript对象,而是个domstringmap对象,domstringmap是html5一种新的含有多个名-值对的交互变量。

四、dataset的操作

您可以像下面这样操作名-值对:

chartinput = [];

for (var item in expense) {

chartinput.push(expense[item]);

}

上面这几行代码作用是让所有的自定义的属性值塞到一个数组中。

如果你想删掉一个data属性,可以这么做:

delete expenseday2.dataset.meal;

如果你想给元素添加一个属性,可以这么做:

expenseday2.dataset.dessert = 'icecream';

五、跟getattribute相比的速度

使用dataset操作data 要比使用getattribute稍微慢些,这里有个页面专门对这两个方法速度做了测试,dataset vs attributes loop,请使用chrome浏览器以及opera 11.1+的浏览器,点击"run test"按钮后,会得到一些数据,如下截图:

但是,如果我们只是处理少量的data数据,这种速度上差异造成的影响是基本上没有的。反而,我们应该看到,使用dataset操作自适应属性要比其他类似getattribute的形式要少很多让人头疼的麻烦,并且更具有可读性。因此,权衡来看,操作自定义属性,dataset操作是上选。

六、什么地方使用dataset

每次你使用自定义data属性的时候,使用dataset去获取名-值对就是个不错的选择。考虑到现在很多浏览器还是把dataset当作不认识的外星生物看待,所以,在实际使用的时候,有必要进行下特征检测,看看是否支持dataset,类似下面的使用:

if(expenseday2.dataset) {

expenseday2.dataset.dessert = 'icecream';

} else {

expenseday2.setattribute('data-dessert', 'icecream');

}

注意:如果你的应用程序会频繁更新data属性值的话,建议使用javascript对象进行数据管理,而不是每次都经由data属性进行更新。

七、css中的data属性

我们可以基于data属性值对相应的元素设置css样式,例如下面这个例子:

html代码如下:

css代码如下:

.mm{width:256px; height:200px;}

.mm[data-name='张含韵']{background:url(http://image.zhangxinxu.com/image/study/s/s256/mm1.jpg) no-repeat;}

.mm[data-name='undefined']{background:url(http://image.zhangxinxu.com/image/study/s/s256/mm3.jpg) no-repeat;}

结果就会出现一个小美女和一个大美女的图片,例如下面在ie7文档模式下的截图:

您可以狠狠地点击这里:html5自定义属性与css3样式demo

八、简单的综合实例

为了展示dataset的应用,这里提供一个demo页面,如果利用dataset制作数据图效果,您可以狠狠地点击这里:html5 dataset下的数据图demo

滑动html5 range控件,可以看到下面的数据以及图形大小跟着改变了,如下截图(截自opera 11.1):

九、结语

使用dataset获取元素的自定义属性是个很不错的方法,随着以后越来越多的浏览器支持,例如firefox浏览器,这个对象属性在实际项目中正式使用是很有可能的。虽然说使用dataset不能提高代码的性能,但是对于简洁代码,提高代码的可读性和可维护性是很有帮助的。

如果您对dataset有兴趣,做了些demo什么的,可以去这里opera github repository玩转你的些小成果。

参考文章:an introduction to datasets

demo支持:cost of electricity €/kwh over the decade

转自:http://www.zhangxinxu.com/wordpress/?p=1693


======================================================
在最后,我邀请大家参加新浪APP,就是新浪免费送大家的一个空间,支持PHP+MySql,免费二级域名,免费域名绑定 这个是我邀请的地址,您通过这个链接注册即为我的好友,并获赠云豆500个,价值5元哦!短网址是http://t.cn/SXOiLh我创建的小站每天访客已经达到2000+了,每天挂广告赚50+元哦,呵呵,饭钱不愁了,\(^o^)/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值