Attribute和Property都被翻译成“属性”,但是它们的本质不同。
(1)例如:“桌子上有个苹果”。Attribute仅仅是描述了这个“有苹果”的事实,而Property则是直指那个桌子上的苹果。这里的苹果是一个实体,用Attribute来描述只能说明这个事件的事实。它无法准确的描述出具体是哪个苹果在桌子上。
(2)Attribute无法确切表示一个事务。而Property则是直指实体的,可以准确描述事物。如果要用Attribute准确的描述一个东西,只能用文字描述,这样的代价也比Property高了许多。
(3)Property是保存在记忆(memory)中的,虽然一开始很准确,但是无法长期保存。我们经常会把需要长期保存的东西用文字描述下来,这时候就需要用到Attribute。而且Attribute和Property并不冲突,我们经常会翻阅一些旧资料来补充我们渐淡的记忆。
(4)Attribute是标记语言的概念,标记语言本身是一种文本,所以Attribute这种文本方式描述的性质在标记语言中很容易使用。而Property则是保存在内存(memory)中,而内存会随着程序运行结束被释放,因此变得无法长期储存。
在JavaScript中,DOM对象通常都是多重继承的。同时继承了HTML和JavaScript的Object。Object是完完全全的内存对象,所以使用的是Property,而HTML本身是标记语言所以使用的是Attribute。
当这两个东西被继承到同一个对象上的时候经常会让人混淆起来。由于一些Attribute是很常用的,比如id、class等,所以DOM把它们映射到了Property上以方便使用。这样我们就会遇到一个对象同时具有id这个Attribute和Property(由于class是保留字,所以它被映射到Property上时变成了className)。
虽然被DOM这样一搞就变得很乱,但是我们这样理解之后就很简单。只要是HTML标签上设置的属性就是Attribute,而直接在JavaScript中用点运算符操作的DOM对象属性就是Property。还有一些HTML自带的属性,它们同时是Attribute和Property。Attribute的数据类型永远都是字符串,而Property就可以非常丰富。
|