定义html5的,HTML5的data-*自己定义属性

HTML5添加了一项新功能是自己定义数据属性。也就是data-*自己定义属性。在HTML5中我们能够使用以data-为前缀来设置我们须要的自己定义属性,来进行一些数据的存放。当然高级浏览器下可通过脚本进行定义和数据存取。在项目实践中很实用。眼下採取这样的做法的框架也有许多,最常见的当属jQueryMobile。

详细用法例下:

$("#head").attr("data-home","new");或者纯js做法:

在IE浏览器里,我们通过获取对象后直接调用就能够了

document.getElementById("head").["data-home"];

document.getElementById("head").["data-home"] = "new";在火狐和谷歌浏览器里。我们能够通过getAttribute方法来实现调用:

document.getElementById("head").getAttribute("data-home");

document.getElementById("head").setAttribute("data-home","new");再HTML5中的简洁操作方法:(dataset属性存取data-*自己定义属性的值)

这样的方式通过訪问一个元素的 dataset 属性来存取 data-* 自己定义属性的值。

这个 dataset 属性是HTML5 JavaScript API的一部分,用来返回一个全部选择元素 data- 属性的DOMStringMap对象。

使用这样的方法时。不是使用完整的属性名,如data-home来存取数据,应该去掉data-前缀。

另一点特别注意的是:data-属性名假设包括了连字符。比如:data-date-of-birth 。连字符将被去掉。并转换为驼峰式的命名,前面的属性名转换后应该是:dateOfBirth。

var el = document.querySelector('#head');

console.log(el.id);

console.log(el.dataset);//一个DOMStringMap

console.log(el.dataset.home);

console.log(el.dataset.author);

console.log(el.dataset.dateOfBirth);

el.dataset.dateOfBirth = '1985-01-05'; // 设置data-date-of-birth的值.

//推断属性

console.log('testAttr' in el.dataset);//false

el.dataset.testAttr = 'testAttr';

console.log('testAttr' in el.dataset);//true

假设你想删掉一个 data-属性 ,能够这么做: delete el.dataset.home ;  或者 el.dataset.home = null;。

这样操作起来是不是很的方便。但有些浏览器可能还不支持。

所以在此期间最好用的getAttribute和setAttribute来操作或配合jquery进行使用。

data-属性选择器

在实际开发时,能够依据自己定义的data-属性选择相关的元素。比如使用querySelectorAll选择元素:

//选择全部包括'data-div'属性的元素

document.querySelectorAll ('[data-div]') ;

//选择全部包括'data-a-href' 属性值为red的元素

document.querySelectorAll ('[data-a-href="#"]') ;

相同的我们也能够通过data-属性值对对应的元素设置CSS样式,比如以下这个样例:

.head {

width : 256px ;

height : 200px ;

}

.head[data-a='btn-a'] {

color : brown

}

.head[data-a='btn-color'] {

color : red

}

button按钮
button按钮
欢迎大家关注我的博客!如有疑问,请加QQ群:135430763共同学习!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值