为了账号安全,请及时绑定邮箱和手机立即绑定

关于自定义属性的获取问题,把自定义属性写在行间,问什么获取不到值?

关于自定义属性的获取问题,把自定义属性写在行间,问什么获取不到值?

偶然的你 2018-12-20 18:14:36
<body><div id="div1" index="2"></div><script type="text/javascript">var div = document.getElementById('div1');alert(div.index)----》已在行间自定义属性值设为2,为什么获取不到?div.index = 1;----》在js中设置了自定义属性值为1之后,在下面一行可以获取到值?alert(div.index)div.setAttribute('index','3');alert(div.getAttribute('index'))//alert(div.getAttribute('index'))//alert(div['id'])</script></body>
查看完整描述

1 回答

?
UYOU

TA贡献1878条经验 获得超4个赞

因为div.index === undefined,当执行div.index = 1;时,index才被定义。

不修改HTML

在IE中:

var index = document.getElementById('div1').index;

Other:

var index = document.getElementById('div1').getAttribute(`index`);

HTML5

如果你想要使用的是 HTML 5 的自定义属性,你应该将属性命名为data-*(即date-index)。

这样使用它:

var index = document.getElementById('div1').dataset.index;


查看完整回答
反对 回复 2019-01-08
  • 1 回答
  • 0 关注
  • 410 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信