用data-xxx自定义的属性名最好全部小写

今天写一个组件,在某处为了传值在input标签中定义了一个data-courseInfo属性,然后用jquery的data(“courseInfo”)去取,却死活取不到值,打出的是undefined,而用jquery的attr("data-courseInfo")去取,却能取到。

后来在浏览器中查年,发现我定义的属性名被浏览器改成了小写的data-courseinfo, 真是哭笑不得。。。

也是,因为HTML属性是不区分大小写的,而web标准又要求属性名要小写,so,以后属性名就都小写吧,省得再出现类似今天的问题。

最后提一下,个人认为attr()之所以能得到值,可能是因为它内部先进行了一次toLowerCase()操作,因为HTML属性名不区分大小写嘛。


另附,data()和attr()取值的区别:

attr(): 返回的永远是string类型的,例如我存了一个stringify的json对象,则返回的仍是此对象的string序列;

data(): 返回数据本来的值,同上例,它返回的就是json对象本身。当存了数值或布尔值时,它返回的也是数值或布尔值。所以优先推荐用此方法。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值