原型对象prototype和原型属性[[Prototype]]
構造器:可以被 new 運算符調用, Boolean,Number,String,Date,RegExp,Error,Function,Array,Object 都是構造器,他們有各自的實現方式。
比如:var s=new String("test")
s的 [[Prototype]] 內部屬性設定為標準內置的字符串原型對象,它是 String.prototype 的初始值。
s的 [[Class]] 內部屬性設定為 "String"。
s的 [[Extensible]] 內部屬性設定為 true。
s的 [[PrimitiveValue]] 內部屬性設定為 ToString("test")。
除這些內置全局對象的構造器之外,還有創建的函數對象也可以用new運算符調用,因為在創建函數對象的過程中,設定了其內部屬性[[Construct]],同時給它設置一個原型對象,這個原型對象和new Object創建的對象一樣。
這里說明下函數對象的[[call]] ,[[Construct]],
var f=function(a,b,c){}
f()調用[[call]]內部屬性方法,建立執行環境,返回返回值。
var ff=new f()調用[[Construct]]內部方法,創建一個空對象,并對其設置內部屬性和方法,比如[[Prototype]]屬性指向f的prototype。并以該對象為 this 值,調用參數列表,調用f的 [[Call]] 內部屬性,如果返回一個對象則返回該對象,否則返回此前創立的空對象。
所以每個構造器有一個原型對象prototype。
每個對象都有一個內部屬性[[Prototype]],它指向自己的構造函數的原型對象,同理,其構造函數的原型對象也有有一個內部屬性[[Prototype]]指向自己的原型對象,這就形成原型鏈。當然這個原型鏈不是無窮的,Object的原型對象的[[Prototype]]是null。
拿Array為例:
Array的原型是數組原型對象,Array構造器的[[Prototype]]是函數原型對象。
當var arr=new Array()時,
arr的內部屬性[[Prototype]]指向Array.prototype。
下面就來驗證下:
var a=Array.call(this,2)
結果a是長度為2的空數組。其中call方法就繼承自 Function.prototype
arr.push(1);
push繼承自 Array.prototype
console.log(arr.prototype) //結果為 undefined,可見其沒有原型對象了。
var arrNew=new arr() //TypeError: object is not a function 因為沒有內部屬性[[Construct]],拋出異常
再看
例2:
var f=function(){}
console.log(f.prototype) //Object {}
var ff=new f() //{}對象
轉載于:https://www.cnblogs.com/mufc-go/p/3544852.html
總結
以上是生活随笔為你收集整理的原型对象prototype和原型属性[[Prototype]]的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C# 通过ImportNode Appe
- 下一篇: AVAudioSession