When writing HTML source code, you can define attributes on your HTML elements. Then, once the browser parses your code, a corresponding DOM node will be created. This node is an object, and therefore it has properties.node
For instance, this HTML element:ide
<input type="text" value="Name:">
has 2 attributes.this
Once the browser parses this code, a HTMLInputElement object will be created, and this object will contain dozens of properties like: accept, accessKey, align, alt, attributes, autofocus, baseURI, checked, childElementCount, childNodes, children, classList, className, clientHeight, etc.spa
For a given DOM node object, properties are the properties of that object, and attributes are the elements of the attributes
property of that object.翻譯
Update: When a DOM node is created for a given HTML element, a corresponding property is created for each attribute in the HTML source code. For instance, for this HTML element:code
<input type="text" value="Name:">
the corresponding DOM node will have a type
and a value
property (among others). However, when the user manually changes the value of the input box, the value
property will reflect this change. So if the user inputs "John"
into the input box, then:orm
input.value // returns "John"
whereas:element
input.getAttribute('value') // returns "Name:"
The value
property reflects the current text-content inside the input box, whereas the value
attribute contains the initial text-content of the value
attribute from the HTML source code.get
So if you want to know what's currently inside the text-box, read the property. If you, however, want to know what the initial value of the text-box was, read the attribute.input
簡單翻譯,property是可變的,attribute是初始值。
但仍是有不少問題:
.style 與 getAttribute('style')徹底不同