最近,我看到越来越多的人在HTML标记中使用自定义属性,主要是为了嵌入一些额外的数据,以便在javascript代码中使用。
我希望收集一些反馈,了解使用自定义属性是否是一种良好的实践,以及一些替代方法是什么。
看起来它确实可以简化服务器端和客户端代码,但它也不符合W3C。
我们应该在我们的web应用中使用自定义HTML属性吗?为什么或者为什么不?
对于那些认为自定义属性是一件好事的人来说:在使用这些属性时,需要记住的是什么?
对于那些认为自定义属性是坏事的人来说:你用什么替代方法来完成类似的事情?
更新:--我最感兴趣的是各种方法背后的推理,以及为什么一种方法比另一种方法更好的原因。我想我们都能想出4-5种不同的方法来完成同样的事情。(隐藏元素、内联脚本、额外的类、从ids解析信息等)。
更新2:似乎HTML5 data-属性特性在这里有很多支持(我倾向于同意,它看起来是一个可靠的选项)。到目前为止,我还没有看到对这一建议的反驳。是否有任何问题/陷阱需要担心使用这种方法?还是仅仅是对当前W3C规范的“无害”失效?
发布于 2017-04-19 20:42:47
我知道有人反对,但我想出了一个超短的解决方案。如果您想使用像“我的”这样的自定义属性,例如:
<a href="test.html" mine-one="great" mine-two="awesome">Test</a>然后,您可以像jquery.data()一样运行这段代码来获取一个对象。
var custom_props = {} ;
$.each($(".selector")[0].attributes, function(i,x) {
if (this.specified && x.name.indexOf("mine-") !== -1)
self.new_settings[x.name.replace("modal-","")] = x.value;
});https://stackoverflow.com/questions/992115
复制相似问题