- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
var person = { name :"dummy", personal_details: { age : 22, country : "USA" } };
var bob = Object.create(person);
bob.name = "bob";
bob.personal_details.age = 23;
console.log(bob.personal_details === person.personal_details);
// true : since it does not shadow object of prototype object
console.log(bob.name === person.name);
// false : since it shadows name
////now
bob.personal_details = {a:1};
console.log(bob.personal_details === person.personal_details);
最佳答案
下面的例子可以很容易地说明发生了什么:
通过原型(prototype)链访问personal_details
var person = { name :"dummy", personal_details: { age : 22, country : "USA" } }
var bob = Object.create(person)
bob.name = "bob"
bob.personal_details.age = 23
输出如下:
console.log( bob );
/// { name :"bob", personal_details: { age : 23, country : "USA" } }
console.log( person )
/// { name :"dummy", personal_details: { age : 23, country : "USA" } }
现在在人员对象上设置了23岁,
because bob.personal_details
是通过bob的原型(prototype)链直接引用
person.personal_details
的对象。导航到对象结构后,就可以直接使用
person.personal_details
对象。
personal_details
属性,则该原型(prototype)链接将被更本地的属性覆盖。
bob.personal_details = { a: 123 }
现在的输出是:
console.log( bob );
/// { name :"bob", personal_details: { a : 123 } }
console.log( person )
/// { name :"dummy", personal_details: { age : 23, country : "USA" } }
因此,从现在开始,通过访问
bob.personal_details
,您引用的是
{ a: 123 }
对象,而不是person的原始
{ age : 23, country : "USA" }
对象。所做的所有更改都将在该对象上发生,并且基本上与
bob
或
person
对象无关。
delete bob.personal_details
您最终使原始原型(prototype)链接恢复为
person.personal_details
(因为您已删除添加的本地属性),因此控制台日志将显示:
console.log( bob );
/// { name :"bob", personal_details: { age : 23, country : "USA" } }
基本上,JavaScript引擎将沿原型(prototype)链进行工作,直到找到每个原型(prototype)对象上要请求的属性或方法为止。项设置的距离越远,这意味着它将在以后向下覆盖其他项。
delete bob.personal_details
没有,不再分配给bob的实际属性称为
personal_details
,
delete
将仅在当前对象上起作用,而不会遵循原型(prototype)链。
bob : { }
person : { name: 'dummy', personal_details: { age: 22 } }
Object : { toString: function(){ return '[Object object]'; } }
因此,举例来说,我想访问
bob.toString
。
toString
是JavaScript基本对象
Object
上存在的方法,该对象是几乎所有内容的基本原型(prototype)。当解释器获得对对象上特定方法或属性的读取请求时,它将遵循以下事件链:
bob
是否具有称为toString
的属性? 编号 bob.__proto__
(即person
)是否具有称为toString
的属性? 编号 bob.__proto__.__proto__
(即Object
)是否具有称为toString
的属性? 是 function(){ return '[Object object]'; }
的引用toString
方法的引用。如果未在
Object
上找到该属性,则很可能会触发未定义属性的错误(因为它是链中的最后一个)。
toString
上定义
bob
方法-因此:
bob : { toString: function(){ return '[Bob]'; } }
person : { name: 'dummy', personal_details: { age: 22 } }
Object : { toString: function(){ return '[Object object]'; } }
如果我们尝试再次读取bob上的
toString
方法,则这次得到:
bob
是否具有称为toString
的属性? 是。 toString
方法。这意味着
bob.toString()
将返回
[Bob]
而不是
[Object object]
。
bob.toString --- is a read request
bob.toString = function(){} --- is a write request
bob.personal_details --- is a read request
bob.personal_details = {} --- is a write request
bob.personal_details.age = 123 --- is a read request, then a write request.
最后一项是引起困惑的一项。该过程将遵循以下路线:
bob
是否具有称为personal_details
的属性? 编号 person
是否具有称为personal_details
的属性? 是。 { age: 22 }
的引用,该引用存储在内存中的某个位置。 personal_details
对象,我们将其切换到写入请求,因为
=
equals左侧的属性或变量始终是赋值。
123
写入对象age
上的属性{ age: 22 }
(bob.personal_details) --- read
(personal_details.age = 123) --- write
如果
bob
拥有自己的
personal_details
属性,则过程将相同,但是写入的目标对象将不同。
Its difficult to digest that properties on prototype objects are treated as READ_ONLY, but if property is an object then one can get hold of it and can freely modify its properties !! Is my understanding right ?
关于javascript - Javascript原型(prototype)继承和对象属性阴影,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14379208/
你能比较一下属性吗 我想禁用文本框“txtName”。有两种方式 使用javascript,txtName.disabled = true 使用 ASP.NET, 哪种方法更好,为什么? 最佳答案 我
Count 属性 返回一个集合或 Dictionary 对象包含的项目数。只读。 object.Count object 可以是“应用于”列表中列出的任何集合或对
CompareMode 属性 设置并返回在 Dictionary 对象中比较字符串关键字的比较模式。 object.CompareMode[ = compare] 参数
Column 属性 只读属性,返回 TextStream 文件中当前字符位置的列号。 object.Column object 通常是 TextStream 对象的名称。
AvailableSpace 属性 返回指定的驱动器或网络共享对于用户的可用空间大小。 object.AvailableSpace object 应为 Drive 
Attributes 属性 设置或返回文件或文件夹的属性。可读写或只读(与属性有关)。 object.Attributes [= newattributes] 参数 object
AtEndOfStream 属性 如果文件指针位于 TextStream 文件末,则返回 True;否则如果不为只读则返回 False。 object.A
AtEndOfLine 属性 TextStream 文件中,如果文件指针指向行末标记,就返回 True;否则如果不是只读则返回 False。 object.AtEn
RootFolder 属性 返回一个 Folder 对象,表示指定驱动器的根文件夹。只读。 object.RootFolder object 应为 Dr
Path 属性 返回指定文件、文件夹或驱动器的路径。 object.Path object 应为 File、Folder 或 Drive 对象的名称。 说明 对于驱动器,路径不包含根目录。
ParentFolder 属性 返回指定文件或文件夹的父文件夹。只读。 object.ParentFolder object 应为 File 或 Folder 对象的名称。 说明 以下代码
Name 属性 设置或返回指定的文件或文件夹的名称。可读写。 object.Name [= newname] 参数 object 必选项。应为 File 或&
Line 属性 只读属性,返回 TextStream 文件中的当前行号。 object.Line object 通常是 TextStream 对象的名称。 说明 文件刚
Key 属性 在 Dictionary 对象中设置 key。 object.Key(key) = newkey 参数 object 必选项。通常是 Dictionary 
Item 属性 设置或返回 Dictionary 对象中指定的 key 对应的 item,或返回集合中基于指定的 key 的&
IsRootFolder 属性 如果指定的文件夹是根文件夹,返回 True;否则返回 False。 object.IsRootFolder object 应为&n
IsReady 属性 如果指定的驱动器就绪,返回 True;否则返回 False。 object.IsReady object 应为 Drive&nbs
FreeSpace 属性 返回指定的驱动器或网络共享对于用户的可用空间大小。只读。 object.FreeSpace object 应为 Drive 对象的名称。
FileSystem 属性 返回指定的驱动器使用的文件系统的类型。 object.FileSystem object 应为 Drive 对象的名称。 说明 可
Files 属性 返回由指定文件夹中所有 File 对象(包括隐藏文件和系统文件)组成的 Files 集合。 object.Files object&n
我是一名优秀的程序员,十分优秀!