常建57

路漫漫其修远兮。。。

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

html5 可以为元素添加自定义属性,但是要添加前缀data-。(下面这个例子中的自定义属性的命名,其实是不规范的,不应该包含大写字符,例如:data-myName 应改命名为:data-myname. 应为我们在维护别人的代码,所以就会遇到如下的问题。)

  <div class="disabled myClass" id="mDiv" data-appId='12456' data-myName="mDiv">class test</div>

定义好属性之后该如何访问属性呢,有两种方式:1.通过元素的dataset 属性来直接访问属性值。这也就是可能会有问题的地方!!! 使用下面的代码执行不成功。

                var div = document.getElementById("mDiv");
                alert(div.dataset.appId);//undefined
                alert(div.dataset.myName);//undefined

正确的代码:

                var div = document.getElementById("mDiv");
                alert(div.dataset.appid);//123456
                alert(div.dataset.myname);//mDiv

为了省去不必要的麻烦,推荐做法 是使用getAttribute() 自己来取值(俗话说自己动手丰衣足食):

var div = document.getElementById("mDiv");
var temp = div.getAttribute("data-appId");
 alert(temp);//123456

 <b>test</b>

posted on 2014-10-30 12:09  常建57  阅读(288)  评论(0编辑  收藏  举报