Attribute和Property的区别

Attribute和Property的区别

attributeXML元素中的概念,用于描述XML标签的附加信息,即XML标签的属性,propertyJavaScript对象中的概念,用于描述JavaScript对象的成员,即JavaScript对象的属性。

描述#

在描述HTML时需要为其设定一些属性值的键值对用以描述标签:

Copy
<input id="this-input" type="text" value="test" />

上述标签节点就定义了3attribute

Copy
id: this-input type: text value: test

而浏览器在解析这段HTML后,就会创建一个Element对象,该对象包括很多属性property例如idinnerHTMLouterHTML等等,而对于这个Js对象,其许多属性property都与这个节点元素具有相同或相似名称的attribute,但这不是一对一的关系。

  • 某些attribute存在与property1:1的映射,例如id属性。
  • 某些attribute存在与property1:1的映射但名称不同,例如class属性。
  • 某些attribute不存在与property的映射,例如自定义的customize属性。

实例#

首先将<input>标签中的type进行更改:

Copy
<input id="this-input" type="t" value="test" />

此时用Js取得对象的attribute以及property

Copy
console.log(document.querySelector("#this-input").getAttribute("type")); // t // attribute console.log(document.querySelector("#this-input").type); // text // property

可以看到对于property而言,其会自动修正不正确的值,而对于attribute而言,其保留了关于DOM节点元素原本的值,可以说attribute从语义上, 更倾向于不可变更的值,而property从语义上更倾向于在其生命周期中是可变的值。下面是一个同样的例子,当更改输入框中的test值为其他值比如t时,分别取得其attribute以及property

Copy
console.log(document.querySelector("#this-input").getAttribute("value")); // test console.log(document.querySelector("#this-input").value); // t console.log(document.querySelector("#this-input").defaultValue); // test

可以看到attribute依旧保留了其原始值,而property获得了改变后的值,如果需要在property获得其原始值可以使用defaultValue属性。
如果在DOM节点自定义了某些attribute,其不一定会同步到property,同样在property定义的属性不一定会同步到attribute

Copy
<input id="another-input" type="type" customize="test" />
Copy
console.log(document.querySelector("#another-input").customize); // undefined console.log(document.querySelector("#another-input").getAttribute("customize")); // test

代码示例#

Copy
<!DOCTYPE html> <html> <head> <title>Attribute Property</title> </head> <body> <input id="this-input" type="t" value="test" /> <input id="another-input" type="type" customize="test" /> </body> <script type="text/javascript"> console.log(document.querySelector("#this-input").type); // text console.log(document.querySelector("#this-input").getAttribute("type")); // t console.log(document.querySelector("#another-input").customize); // undefined console.log(document.querySelector("#another-input").getAttribute("customize")); // test </script> </html>

每日一题#

Copy
https://github.com/WindrunnerMax/EveryDay

参考#

Copy
https://www.jianshu.com/p/8415edb391ce https://juejin.im/post/5bea695ae51d45196e141f7f https://stackoverflow.com/questions/6003819/what-is-the-difference-between-properties-and-attributes-in-html/6377829#6377829
posted @   WindRunnerMax  阅读(199)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示
CONTENTS