JS中__proto__和prototype是兩個與原型相關的屬性,它們在功能上稍有不同。本文將具體介紹并比較這兩者的區別,并提供相應的代碼示例。
首先,我們先來了解一下它們的含義和用途。
proto
__proto__是對象的一個內置屬性,它用于指向該對象的原型。每個對象都有一個__proto__屬性,包括自定義對象、內置對象和函數對象。通過__proto__屬性,我們可以訪問和操作對象的原型鏈。
讓我們來看一個例子:
let obj = {}; console.log(obj.__proto__); // 輸出:Object {} let arr = []; console.log(arr.__proto__); // 輸出:Array [] function func() {} console.log(func.__proto__); // 輸出:[Function]
登錄后復制
上面的代碼中,我們創建了一個空對象obj,并訪問了它的__proto__屬性??梢钥吹剑琽bj.__proto__指向了一個Object{}對象。同樣,我們還創建了一個空數組arr,并訪問了它的__proto__屬性,結果是arr.__proto__指向了一個Array []對象。而對于函數對象func來說,它的__proto__指向的是一個[Function]對象。
總結起來,__proto__屬性用于指向對象的原型,我們可以通過它來訪問和操作原型鏈。
prototype
prototype是函數對象獨有的屬性,它指向了一個原型對象。每個函數對象都有一個prototype屬性,但它只有在這個函數作為構造函數使用時才有意義。
我們來看一個示例:
function Person() {} console.log(Person.prototype); // 輸出:Person {}
登錄后復制
上面的代碼中,我們定義了一個Person函數對象,并訪問了它的prototype屬性??梢钥吹剑琍erson.prototype指向了一個Person{}對象。
prototype屬性的主要作用是在構造函數模式下,用于構建實例對象的原型鏈。當我們使用構造函數來創建一個對象時,它的__proto__屬性會指向構造函數的prototype屬性。
let person = new Person(); console.log(person.__proto__ === Person.prototype); // 輸出:true
登錄后復制
上面的代碼中,我們使用了Person構造函數來創建了一個對象person。結果表明,person.__proto__指向了Person.prototype。
區別和聯系
__proto__和prototype都與對象的原型相關,它們之間的聯系和區別如下:
- __proto__是實例對象的屬性,用于指向該對象的原型;而prototype是構造函數的屬性,用于指向構造函數的原型對象。__proto__是讀取并訪問對象的原型鏈的屬性,可以在實例對象上直接訪問;而prototype是構造函數的屬性,只能在構造函數內部訪問。__proto__可以通過Object.setPrototypeOf()或直接賦值的方式來修改;而prototype只能在構造函數內部通過函數名.prototype來修改。__proto__是非標準的屬性,只有部分瀏覽器支持;而prototype是標準屬性,所有的對象和函數都有。
下面的代碼示例用于進一步說明這兩者的區別與聯系:
function Animal() {} Animal.prototype.eat = function() { console.log("Animal is eating"); }; function Dog() {} Dog.prototype = Object.create(Animal.prototype); Dog.prototype.bark = function() { console.log("Dog is barking"); }; const dog1 = new Dog(); dog1.eat(); // 輸出:Animal is eating dog1.bark(); // 輸出:Dog is barking console.log(dog1.__proto__ === Dog.prototype); // 輸出:true console.log(Dog.prototype.__proto__ === Animal.prototype); // 輸出:true
登錄后復制
上面的代碼中,我們通過定義Animal構造函數和Dog構造函數,創建了一個繼承關系。通過__proto__和prototype屬性,我們可以訪問到對象的原型鏈,并且證明了它們之間的聯系。
綜上所述,__proto__和prototype在JS中都與原型相關,但在功能和使用方式上有所不同。了解它們的區別可以幫助我們更好地理解JS中的原型機制,并在編寫代碼時更靈活地利用它們。