js 中对象--对象结构(原型链基础解析)

对于本篇对于如何自定义对象、和对象相关的属性操做不了解的话,能够查我对这两篇博客。了解这两篇能够更容易理解本篇文章函数

       

 用构造函数建立了一个对象spa

 obj对象的自己建立了两个属性  x=1   ,y=2    prototype

 对象本的的两个属性都有属性特征  writable是否可写的,enumerable是否可枚举的 configurable是否可重置的,getter  ,settercode

 obj对象自己也有三大特性    proto 原型    class 类     extensible可拓展对象

 foo.prototype是对象上的原型 , foo.prototype也是个对象。blog

 z=3是foo.prototype是对象上原型的属性。继承

 再往上object.prototype是一个顶级属性,是全部对象的原型。ip

 再上往上就是null 空了。  此时就造成了一个原型链。原型链

 我再用代码来一一解析,用演示代码再向你们详细解释:get

 

 1 <script>
 2       function Foo(){    //声名一个函数FOO
 3 
 4       }
 5       alert(typeof Foo.prototype)    //Foo.prototype 是一个对象。也能够是obj对象上的原型
 6       Foo.prototype.z =3    //设置了原型属性z为3
 7       var obj = new Foo()    //用构建函数来建立了obj对象
 8       obj.x = 1;            //x=1是obj对象上自己的属性
 9       obj.y = 2;           //y=2是obj对象上自己的属性
10       alert(obj.x)         //=>1 对过查询对象,咱们是否获得这个属性值
11       alert(obj.y)         //=>1 对过查询对象,咱们是否获得这个属性值
12       alert(obj.z)        //=》3 z不是obj自己的属性,是他原型上的属性,若是自己没有,能够向他的原型链上的原型来查找,获得z属性
13       alert(obj.toString())//=toString是顶级object对象上的属性,先是查找原型上有没有这个属性,若是没有再往原型链上顶级的object对象上找
14 </script>

 

再来了解一下获得对象上属性的优先级。

若是在对象自己上有这个属性,则获得的是对象上自己的属性。

若是对象自己上有这个属性,则向他的原型上查找。

若是再没有再向顶级属性上查找。

若是原型上和对象自己上都有这个属性,则仍是先用对象自己的属性

为了让你们更好的了解,演示代码以下:

 1 <script>
 2       function Foo(){    //声名一个函数FOO
 3 
 4       }
 5       Foo.prototype.z =3    //设置了原型属性z为3
 6       var obj = new Foo()    //用构建函数来建立了obj对象
 7       obj.z = 5     //定义对象的属性Z = 5
 8       alert(obj.z)   //=>5  若是对象上自己定义了属性z ,则先用对象自己的属性
 9       delete obj.z;   //删除对象上自己的属性
10       alert(obj.z);   //=>3再次获取对象的z,结果发现对象自己z的属性被删除了,会自动往对象的原型上查找,获得z=3
11       delete Foo.prototype.z;  //删除对象原型上的z属性
12       alert(obj.z)   //=> undefined 由于对象自己的z属性被删除,原型上的z属性也被删除,再继续往顶级对象Object上查找,没有此属性,返回undefined
13 </script>

经过 var obj = Object.create({x:1}) 来建立对象来解析对象、对象上的原型

其实obj.create圆括号里面定义对象和属性就是obj对象的原型和原型属性,

演示代码以下:

1 <script>
2     var obj = Object.create({z:4})  //Object.create({z:4})是一个对象上的一个原型,z是原型上的属性
3       obj.x = 1      //x是对象自己的属性
4       obj.z = 3         //z是对象自己的属性
5       alert(obj.x)     //=>1  输出的是对象自己的x
6       alert(obj.z)     //=>3  输出的是对象自己的z
7       delete obj.z;    //当咱们删除对象本的z
8       alert(obj.z)    //就是会向原型上面查找原型上有没有这个属性,若是有,z指的是原型上的属性    
9 </script>

经过In来解释某个对象上是否有这个属性:

演示代码以下:

 1 <script>
 2     //用  属性 In  对象来检测 是不是对象上的属性,返回true否是,返回false 则不是
 3      function Foo(){
 4 
 5      }
 6      Foo.prototype.z = 5
 7      var obj = new Foo()
 8      obj.x = 1 ;
 9      obj.y = 2;
10      alert("x" in obj)   //=>true x是对象上自己定义的属性
11      alert("y" in obj)   //=>true y也是对象上自己定义的属性
12      alert("z" in obj)   //=>true z是从对象原型上继承来的属性
13      alert("toString" in obj) //=>true toString是从顶级对象Object上继承来的属性
14      alert("no" in obj)   //=>false  对象本上没有,查找整个原型链都没有这个属性直到null 则反回false,
15 </script>

经过hasOwnProperty查找是不是对象自己的属性,而不是继承来的属性

 1 <script>
 2     //用对象.hasOwnProperty("属性") 来检测是不是对象自己的属性,而不是继承来的
 3      function Foo(){
 4 
 5      }
 6      Foo.prototype.z = 5
 7      var obj = new Foo()
 8      obj.x = 1 ;
 9      obj.y = 2;
10      alert(obj.hasOwnProperty("x")) //=>true   x是对象自己定义的属性,因此返回true
11      alert(obj.hasOwnProperty("z")) //=>false   z是对象原型上继承的属性,因此返回false
12      alert(obj.hasOwnProperty("toString")) //=>false   toString是顶级对象上继承来的属性,因此返回false
13 </script>

咱们最后来看看用var obj = Objcet.create()来建立的对象如何来检测他的属性。

若是想没有任何继续属性的话能够写  var obj = Object.create(null) 则不继承任何属性

演示代码:

 1 <script>
 2      var obj = Object.create({x:1})
 3       obj.y = 2
 4      alert("y" in obj)  //=>true
 5      alert("x" in obj)  //=>true
 6      alert("toString" in obj)  //=>true
 7      alert(obj.hasOwnProperty("x")) //=>false
 8      alert(obj.hasOwnProperty("y"))  //=>true
 9     var obj1 = Object.create(null)
10     alert("toString" in obj1)    //=>false 建立了一个不继承任何属性的对象obj1,直到顶级对象Object对象都不继承
11 </script>
相关文章
相关标签/搜索