1汉规、工廠模式
用于抽象創(chuàng)建特定對象的過程琴许。
優(yōu)點:可以創(chuàng)建多個類似的對象
缺點:沒有解決對象標識問題(即創(chuàng)建的對象是什么類型)顽聂。
2、構(gòu)造函數(shù)模式
用于創(chuàng)建特定類型對象
構(gòu)造函數(shù)模式和工廠模式的區(qū)別在于:
1.沒有顯示的創(chuàng)建對象
2.屬性和方法直接賦值給 this
3.沒有 return
要創(chuàng)建構(gòu)造函數(shù)實例跳纳,要使用 new 操作符,過程如下:
1.在內(nèi)存中創(chuàng)建一個新對象贪嫂。
2.這個新對象內(nèi)部的 [[Prototype]](即 __ proto __) 特性被賦值給構(gòu)造函數(shù)的 prototype (原型)屬性寺庄。
3.構(gòu)造函數(shù)內(nèi)部的 this 被賦值為這個新對象。
4.執(zhí)行構(gòu)造函數(shù)內(nèi)部的代碼(給新對象添加屬性)。
5.如果構(gòu)造函數(shù)返回非空對象斗塘,則返回該對象饶深,否則,返回剛創(chuàng)建的新對象逛拱。
實例對象中的 constructor 屬性指向 創(chuàng)建該實例的構(gòu)造函數(shù)敌厘。constructor 屬性用于標識對象類型,但一般認為 instanceof 操作符是確定對象類型更靠譜的方式朽合。
構(gòu)造函數(shù)與普通函數(shù)的區(qū)別
唯一的區(qū)別就是調(diào)用方式的不同俱两。構(gòu)造函數(shù)也是函數(shù),并沒有把函數(shù)定義為構(gòu)造函數(shù)的特殊語法曹步。任何函數(shù)只要使用 new 操作符調(diào)用就是構(gòu)造函數(shù)宪彩,而不使用 new 操作符的就是普通函數(shù)。
優(yōu)點:解決了工廠模式無法確定對象標識的問題讲婚。
缺點:構(gòu)造函數(shù)中定義的方法尿孔,在每次創(chuàng)建實例時都定義了一遍。不同實例上相同名稱的函數(shù)卻不相等筹麸』詈希可以通過定義全局方法,賦值給構(gòu)造函數(shù)中的同名方法物赶,從而解決相同邏輯的函數(shù)定義多次的問題白指,但因為定義為了全局函數(shù),也污染了全局作用域酵紫。
3告嘲、原型 模式
理解原型:只要創(chuàng)建一個函數(shù),就會按照特定的規(guī)則為這個函數(shù)創(chuàng)建一個 prototype 屬性(指向原型對象)奖地,默認情況下所有原型對象自動獲得 constructor 屬性橄唬,指向與之關(guān)聯(lián)的構(gòu)造函數(shù)。
原型模式:每一個函數(shù)都有一個 prototype 屬性参歹,指向一個對象仰楚,這個對象包含應(yīng)該有特定引用類型的實例所共享的屬性和方法。
(構(gòu)造函數(shù)創(chuàng)建實例對象時泽示,將 構(gòu)造函數(shù)的 prototype 屬性 賦值給了 實例對象的 [[prototype]] 特性缸血,構(gòu)造函數(shù)的原型對象上有 constructor 屬性指回 構(gòu)造函數(shù)。所以 實例對象的constructor === 原型對象的 constructor === 構(gòu)造函數(shù)械筛,以此來確定實例對象的標識類型捎泻。根據(jù)原型鏈去找。實例與構(gòu)造函數(shù)的原型對象有直接的聯(lián)系埋哟,和構(gòu)造函數(shù)沒有笆豁。constructor 只存在于原型對象上郎汪,實例對象是根據(jù)原型鏈找到的,其本身沒有闯狱。)