摘要:創(chuàng)建對(duì)象與工廠模式的區(qū)別沒(méi)有顯示地創(chuàng)建對(duì)象直接將方法和屬性付給了對(duì)象沒(méi)有語(yǔ)句構(gòu)造函數(shù)應(yīng)該始終以一個(gè)大寫(xiě)字母開(kāi)頭。創(chuàng)建構(gòu)造函數(shù)的實(shí)例,必須使用操作符。
構(gòu)造函數(shù)模式
1.創(chuàng)建對(duì)象ECMAScript中的構(gòu)造函數(shù)可用來(lái)創(chuàng)建特定類(lèi)型的對(duì)象,像Object和Array這樣的原生構(gòu)造函數(shù)。
也可以創(chuàng)建自定義的構(gòu)造函數(shù),從而定義自定義對(duì)象類(lèi)型的屬性和方法。
function Person(name, age, job){ this.name = name; this.age = age; this.job = job; this.showName = function(){ console.log("name = " + this.name); }; } var p1 = new Person("Mike", 20, "student"); var p2 = new Person("Tom", 23, "student"); console.log(p1); console.log(p2);
與工廠模式的區(qū)別:
沒(méi)有顯示地創(chuàng)建對(duì)象
直接將方法和屬性付給了this對(duì)象
沒(méi)有return語(yǔ)句
構(gòu)造函數(shù)應(yīng)該始終以一個(gè)大寫(xiě)字母開(kāi)頭。
創(chuàng)建構(gòu)造函數(shù)的實(shí)例,必須使用new操作符。以這種方式調(diào)用構(gòu)造函數(shù),會(huì)經(jīng)歷以下4個(gè)步驟:
創(chuàng)建一個(gè)新對(duì)象;
將構(gòu)造函數(shù)中的作用域賦給新對(duì)象(this就指向了這個(gè)對(duì)象)
執(zhí)行構(gòu)造函數(shù)中的代碼(為這個(gè)新對(duì)象添加屬性)
返回新對(duì)象
對(duì)象有一個(gè)constructor用來(lái)標(biāo)識(shí)對(duì)象類(lèi)型。p1和p2對(duì)象,都有一個(gè)constructor(構(gòu)造函數(shù))屬性,該屬性指向Person。
console.log("p1.constructor="); console.log(p1.constructor); console.log("p1.constructor === Person:"); console.log(p1.constructor === Person); console.log("p2.constructor="); console.log(p2.constructor); console.log("p2.constructor === Person:"); console.log(p2.constructor === Person);
但是,提到檢測(cè)對(duì)象類(lèi)型,還是instanceof操作符要更可靠些。Person構(gòu)造函數(shù)創(chuàng)建的所有對(duì)象,既是Object的實(shí)例,也是Person的實(shí)例。
console.log("p1 instanceof Object:"); console.log(p1 instanceof Object); console.log("p1 instanceof Person:"); console.log(p1 instanceof Person); console.log("p2 instanceof Object:"); console.log(p2 instanceof Object); console.log("p2 instanceof Person:"); console.log(p2 instanceof Person);2.觀察Person構(gòu)造函數(shù)涉及到的原型鏈
console.log("Person.prototype="); console.log(Person.prototype); console.log("Person.prototype === Function.prototype;"); console.log(Person.prototype === Function.prototype); //false console.log("-----分割線-----"); console.log("Person.prototype.constructor === Person:"); //true console.log(Person.prototype.constructor === Person); //true console.log("-----分割線-----"); console.log("Person.prototype.__proto__ === Object.prototype:"); //true console.log(Person.prototype.__proto__ === Object.prototype); //true console.log("-----分割線-----"); console.log("Person.__proto__="); console.log(Person.__proto__); console.log("Person.__proto__ === Function.prototype:"); console.log(Person.__proto__ === Function.prototype); //true console.log("-----分割線-----");3.觀察p1實(shí)例對(duì)象涉及到的原型鏈
console.log("p1.prototype="); console.log(p1.prototype); console.log("-----分割線-----"); console.log("p1.__proto__="); console.log(p1.__proto__); console.log("p1.__proto__ === Person:"); console.log(p1.__proto__ === Person); //false console.log("p1.__proto__ === Person.prototype:"); console.log(p1.__proto__ === Person.prototype); //true console.log("-----分割線-----"); console.log("p1.__proto__.constructor === Person:"); console.log(p1.__proto__.constructor === Person); console.log("-----分割線-----"); console.log("p1.__proto__.__proto__="); console.log(p1.__proto__.__proto__); console.log("p1.__proto__.__proto__ === Object.prototype:"); console.log(p1.__proto__.__proto__ === Object.prototype); //true console.log("-----分割線-----");4.觀察下p1.showName屬性引用的函數(shù)
console.log("p1.showName.prototype="); console.log(p1.showName.prototype); console.log("p1.showName.prototype === Function.prototype:"); console.log(p1.showName.prototype === Function.prototype); //false console.log("-----分割線-----"); console.log("p1.showName.prototype.constructor="); console.log(p1.showName.prototype.constructor); console.log("-----分割線-----"); console.log("p1.showName.prototype.__proto__="); console.log(p1.showName.prototype.__proto__); console.log("p1.showName.prototype.__proto__ === Object.prototype:"); console.log(p1.showName.prototype.__proto__ === Object.prototype); //true console.log("-----分割線-----"); console.log("p1.showName.__proto__="); console.log(p1.showName.__proto__); console.log("p1.showName.__proto__ === Function.prototype:"); console.log(p1.showName.__proto__ === Function.prototype); //true console.log("-----分割線-----");原型鏈圖
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/78998.html
摘要:對(duì)象是由構(gòu)造函數(shù)創(chuàng)建而成的,所以它的指向原型鏈圖對(duì)象的原型鏈圖對(duì)象屬性引用的匿名函數(shù)的原型鏈圖 Object模式 創(chuàng)建一個(gè)Object實(shí)例,再為其添加屬性和方法。 這是創(chuàng)建自定義對(duì)象最簡(jiǎn)單的方式。 1.創(chuàng)建對(duì)象 // 創(chuàng)建person對(duì)象 var person = new Object(); person.name = Mike; person.age = 20; person.jo...
摘要:組合使用構(gòu)造函數(shù)模式和原型模式構(gòu)造函數(shù)模式用于定義實(shí)例屬性,原型模式用于定義方法和共享的屬性。創(chuàng)建對(duì)象組合使用構(gòu)造函數(shù)模式和原型模式指向構(gòu)造函數(shù),這里要將其恢復(fù)為指向構(gòu)造函數(shù)。另外,這種混合模式,還支持向構(gòu)造函數(shù)傳遞參數(shù)。 組合使用構(gòu)造函數(shù)模式和原型模式 構(gòu)造函數(shù)模式用于定義實(shí)例屬性,原型模式用于定義方法和共享的屬性。 創(chuàng)建自定義類(lèi)型的最常見(jiàn)方式,就是組合使用構(gòu)造函數(shù)模式和原型模式。 ...
摘要:原型模式定義構(gòu)造函數(shù),在構(gòu)造函數(shù)的原型對(duì)象中定義對(duì)象的屬性和方法,并通過(guò)構(gòu)造函數(shù)創(chuàng)建對(duì)象。,屬性存在于實(shí)例對(duì)象中,屬性不存在于實(shí)例對(duì)象中分割線操作符會(huì)在通過(guò)對(duì)象能夠訪問(wèn)給定屬性時(shí)返回,無(wú)論該屬性是存在于實(shí)例中還是原型中。 原型模式 定義構(gòu)造函數(shù),在構(gòu)造函數(shù)的原型對(duì)象中定義對(duì)象的屬性和方法,并通過(guò)構(gòu)造函數(shù)創(chuàng)建對(duì)象。 1.創(chuàng)建對(duì)象 function Person(){}; Person....
摘要:工廠模式用函數(shù)來(lái)封裝,以特定接口創(chuàng)建對(duì)象的細(xì)節(jié)。缺點(diǎn)不能知道對(duì)象識(shí)別的問(wèn)題對(duì)象的類(lèi)型不知道。復(fù)雜的工廠模式定義是將其成員對(duì)象的實(shí)列化推遲到子類(lèi)中,子類(lèi)可以重寫(xiě)父類(lèi)接口方法以便創(chuàng)建的時(shí)候指定自己的對(duì)象類(lèi)型。 工廠模式 用函數(shù)來(lái)封裝,以特定接口創(chuàng)建對(duì)象的細(xì)節(jié)。 1.創(chuàng)建對(duì)象 function createPerson(name, age, job){ var o = new Obj...
摘要:而且在超類(lèi)型的原型中定義的方法,對(duì)子類(lèi)型而言也是不可見(jiàn)的,結(jié)果所有類(lèi)型都只能使用構(gòu)造函數(shù)模式。在主要考慮對(duì)象而不是自定義類(lèi)型和構(gòu)造函數(shù)的情況下,這個(gè)模式也不錯(cuò)。 寫(xiě)在前面 注:這個(gè)系列是本人對(duì)js知識(shí)的一些梳理,其中不少內(nèi)容來(lái)自書(shū)籍:Javascript高級(jí)程序設(shè)計(jì)第三版和JavaScript權(quán)威指南第六版,感謝它們的作者和譯者。有發(fā)現(xiàn)什么問(wèn)題的,歡迎留言指出。 1.原型鏈 將原型鏈作...
閱讀 1911·2021-11-24 09:39
閱讀 2575·2021-10-14 09:43
閱讀 3333·2021-10-08 10:10
閱讀 2355·2021-09-22 15:54
閱讀 2354·2019-08-29 17:20
閱讀 1585·2019-08-28 18:14
閱讀 2385·2019-08-26 13:28
閱讀 1128·2019-08-26 12:16