成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

js原型鏈1

Baaaan / 986人閱讀

摘要:系列文章原型鏈原型鏈函數(shù)對象和普通對象中,萬物皆對象。原型對象在中,每當(dāng)定義一個對象,對象中都會有一些預(yù)定義的屬性。參考文章原型與原型鏈終極詳解附自己理解的原文章中的內(nèi)存分析圖

系列文章:

js原型鏈1
js原型鏈2

1. 函數(shù)對象和普通對象

js中,萬物皆對象。對象分為函數(shù)對象和普通對象。記住Object和Function是js自帶的函數(shù)對象。

console.log(typeof Object); //function
console.log(typeof Function); //function

函數(shù)對象是function;普通對象是object。下面看常用的幾種生成對象的方法:

var o1 = {};
var o2 = new Object;
var o3 = new Object();
var o4 = new Object(undefined);
var o5 = new Object(null);
var o6 = Object.create(Object.prototype);
var o7 = Object.create(null);
console.log(typeof o1); // object
console.log(typeof o2); // object
console.log(typeof o3); // object
console.log(typeof o4); // object
console.log(typeof o5); // object
console.log(typeof o6); // object
console.log(typeof o7); // object

function f1(){};
var f2 = function(){};
var f3 = new Function("str","console.log(str)");
console.log(typeof f1);// function
console.log(typeof f2);// function
console.log(typeof f3);// function

var o8 = new f1();
console.log(typeof o8);// object

記住,凡是通過new Function()或function關(guān)鍵字創(chuàng)建的對象都是函數(shù)對象,其他是普通對象。Object和Function也都是通過new Function()創(chuàng)建的。

2. 原型對象

在js中,每當(dāng)定義一個對象,對象中都會有一些預(yù)定義的屬性。其中函數(shù)對象的一個屬性就是原型對象prototype;普通對象沒有prototype,但有__proto__屬性。打印o1-o8發(fā)現(xiàn),除了o7其他都一樣。

o7:
Object{No Properties} 

其他:
Object{__proto__: Object}

而f1-f3卻都不一樣。

f1: function f1(){}
f2: function (){} // 匿名函數(shù)
f3: function anonymous(str/**/) { // anonymous意思是匿名
        console.log(str)
    }

發(fā)現(xiàn)打印不出prototype,我們直接打印prototype試試:

console.log(typeof f1.prototype);console.log(f1.prototype);
結(jié)果如下:
object
Object{constructor: f1(), __proto__: Object}

console.log(typeof f2.prototype);console.log(f2.prototype);
結(jié)果如下:
object
Object{constructor: (),__proto__: Object}

console.log(typeof f3.prototype);console.log(f3.prototype);
結(jié)果如下:
object
Object{constructor:anonymous(str/**/),__proto__:Object}

再打印Object.prototype和Functjion.prototype試試

console.log(typeof Object.prototype);console.log(Object.prototype);
結(jié)果如下:
object
Object{
    __defineGetter__:__defineGetter__()
    __defineSetter__:__defineSetter__()
    __lookupGetter__:__lookupGetter__()
    __lookupSetter__:__lookupSetter__()
    constructor:Object()
    hasOwnProperty:hasOwnProperty()
    isPrototypeOf:isPrototypeOf()
    propertyIsEnumerable:propertyIsEnumerable()
    toLocaleString:toLocaleString()
    toString:toString()
    valueOf:valueOf()
    get __proto__:__proto__()
    set __proto__:__proto__()
}

console.log(typeof Function.prototype);console.log(Function.prototype);
結(jié)果如下:
function
function () {}
3. 原型對象的作用
var person = function(name){
this.name = name
};
person.prototype.getName = function(){
 return this.name; 
}

var zzz = new person("zzz");
console.log(zzz.getName()); // zzz

原型鏈中增加一個函數(shù),他的實例就可以直接使用這個函數(shù)了。

4. 原理

js在創(chuàng)建對象的時候都有一個__proto__屬性,指向創(chuàng)建它的函數(shù)的prototype屬性。

1. console.log(zzz.__proto__ == person.prototype);// true
2. console.log(person.__proto__ == Function.prototype);// true
3. console.log(person.prototype.__proto__ == Object.prototype);// true
4. console.log(Object.__proto__ == Function.prototype);// true
5. console.log(Function.__proto__ == Function.prototype);//true
6. console.log(Function.prototype.__proto__ == Object.prototype);//true

分析1:zzz是person創(chuàng)建的,所以person.__proto__指向person.prototype.
分析2:person是Function創(chuàng)建的,所以person.__proto__指向Function.prototype.
分析3:person.prototype是個對象,是Object創(chuàng)建的。
分析4:Object是Function創(chuàng)建的。
分析5:Function也是自己創(chuàng)建的,比較特殊。
分析6:Function的prototype是對象,Object創(chuàng)建的。

總結(jié):

1. 有prototype都是object,所以所有prototype的__proto__都指向Object的prototype。
2. Object的prototype的__prototype__特殊,指向null.
3. Function的__proto__也比較特殊,指向自己的prototype.

圖解如下:

另外,原型對象prototype中都有一個constructor屬性,用來引用他的函數(shù)對象,即。

person.prototype.constructor === person;// true
5. 參考文章

JS原型與原型鏈終極詳解
附自己理解的原文章中的內(nèi)存分析圖:

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/81641.html

相關(guān)文章

  • JS基礎(chǔ)-原型原型真的不能一知半解

    摘要:原型鏈和對象的原型是對象實例和它的構(gòu)造函數(shù)之間建立的鏈接,它的值是構(gòu)造函數(shù)的。對象的原型根據(jù)上文提到的構(gòu)造調(diào)用函數(shù)的時候會創(chuàng)建一個新對象,自動將的原型指向構(gòu)造函數(shù)的對象。 showImg(https://segmentfault.com/img/remote/1460000020185197); JS的原型、原型鏈一直是比較難理解的內(nèi)容,不少初學(xué)者甚至有一定經(jīng)驗的老鳥都不一定能完全說清...

    changfeng1050 評論0 收藏0
  • 理解js原型與繼承

    摘要:相當(dāng)于在用原型繼承編寫復(fù)雜代碼前理解原型繼承模型十分重要。同時,還要清楚代碼中原型鏈的長度,并在必要時結(jié)束原型鏈,以避免可能存在的性能問題。 js是一門動態(tài)語言,js沒有類的概念,ES6 新增了class 關(guān)鍵字,但只是語法糖,JavaScript 仍舊是基于原型。 至于繼承,js的繼承與java這種傳統(tǒng)的繼承不一樣.js是基于原型鏈的繼承. 在javascript里面,每個對象都有一...

    wthee 評論0 收藏0
  • js原型 原型 原型的繼承

    摘要:圖片描述缺點是無法實現(xiàn)多繼承可以在構(gòu)造函數(shù)中,為實例添加實例屬性。 對象的方法 Object.assign() 對象可以簡寫 ,如果 key 和 value 相等則可以簡寫 let name = xm; let age = 2; let obj = { name, age, fn(){ // 可以省略函數(shù)關(guān)鍵字和冒號: console.log(2...

    soasme 評論0 收藏0
  • 從實現(xiàn)角度分析js原型

    摘要:從實現(xiàn)角度分析原型鏈歡迎來我的博客閱讀從實現(xiàn)角度分析原型鏈網(wǎng)上介紹原型鏈的優(yōu)質(zhì)文章已經(jīng)有很多了,比如說作為補(bǔ)充,就讓我們換個角度,從實現(xiàn)來分析一下吧本文假設(shè)你對原型鏈已經(jīng)有所了解。 從實現(xiàn)角度分析js原型鏈 歡迎來我的博客閱讀:《從實現(xiàn)角度分析js原型鏈》 網(wǎng)上介紹原型鏈的優(yōu)質(zhì)文章已經(jīng)有很多了,比如說: https://github.com/mqyqingfeng/Blog/issu...

    CompileYouth 評論0 收藏0
  • js原型

    摘要:構(gòu)造函數(shù),實例,原型三者的關(guān)系如下圖構(gòu)造函數(shù)是構(gòu)成整個原型鏈的關(guān)鍵,是他利用將原型傳給了后代。因此,通過操縱構(gòu)造函數(shù)的,就能夠操縱原型鏈,從而對原型鏈進(jìn)行自在的拼接。 要理解js的原型鏈主要就是理清楚以下三者的關(guān)系: 構(gòu)造函數(shù)的protitype屬性 對象的__proto__屬性 對象的constructor屬性 在js中,函數(shù)作為一等公民,它是一個對象,可以擁有自己的屬性,可...

    NervosNetwork 評論0 收藏0
  • 溫故js系列(15)-原型&原型&原型繼承

    摘要:給添加屬性給的原型對象添加屬性原型鏈在中,每個對象都有一個屬性,其保存著的地址就構(gòu)成了對象的原型鏈。實例變量實例函數(shù)原型鏈繼承有了原型鏈,就可以借助原型鏈實現(xiàn)繼承。是中唯一一個處理屬性但是不查找原型鏈的函數(shù)。 前端學(xué)習(xí):教程&開發(fā)模塊化/規(guī)范化/工程化/優(yōu)化&工具/調(diào)試&值得關(guān)注的博客/Git&面試-前端資源匯總 歡迎提issues斧正:原型&原型鏈&原型繼承 JavaScript-原...

    Ethan815 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<