介紹原型模式(prototype)是指用原型實例指向創(chuàng)建對象的種類,并且通過拷貝這些原型創(chuàng)建新的對象。 正文對于原型模式,我們可以利用JavaScript特有的原型繼承特性去創(chuàng)建對象的方式,也就是創(chuàng)建的一個對象作為另外一個對象的prototype屬性值。原型對象本身就是有效地利用了每個構(gòu)造器創(chuàng)建的對象,例如,如果一個構(gòu)造函數(shù)的原型包含了一個name屬性(見后面的例子),那通過這個構(gòu)造函數(shù)創(chuàng)建的對象都會有這個屬性。 在現(xiàn)有的文獻(xiàn)里查看原型模式的定義,沒有針對JavaScript的,你可能發(fā)現(xiàn)很多講解的都是關(guān)于類的,但是現(xiàn)實情況是基于原型繼承的JavaScript完全避免了類(class)的概念。我們只是簡單從現(xiàn)有的對象進(jìn)行拷貝來創(chuàng)建對象。 真正的原型繼承是作為最新版的ECMAScript5標(biāo)準(zhǔn)提出的,使用Object.create方法來創(chuàng)建這樣的對象,該方法創(chuàng)建指定的對象,其對象的prototype有指定的對象(也就是該方法傳進(jìn)的第一個參數(shù)對象),也可以包含其他可選的指定屬性。例如Object.create(prototype, optionalDescriptorObjects),下面的例子里也可以看到這個用法: // 因為不是構(gòu)造函數(shù),所以不用大寫 Object.create運(yùn)行你直接從其它對象繼承過來,使用該方法的第二個參數(shù),你可以初始化額外的其它屬性。例如: var vehicle = { 這里,可以在Object.create的第二個參數(shù)里使用對象字面量傳入要初始化的額外屬性,其語法與Object.defineProperties或Object.defineProperty方法類型。它允許您設(shè)定屬性的特性,例如enumerable, writable 或 configurable。 如果你希望自己去實現(xiàn)原型模式,而不直接使用Object.create 。你可以使用像下面這樣的代碼為上面的例子來實現(xiàn): var vehiclePrototype = { 總結(jié)原型模式在JavaScript里的使用簡直是無處不在,其它很多模式有很多也是基于prototype的,就不多說了,這里大家要注意的依然是淺拷貝和深拷貝的問題,免得出現(xiàn)引用問題。 同步與推薦本文已同步至目錄索引:深入理解JavaScript系列 深入理解JavaScript系列文章,包括了原創(chuàng),翻譯,轉(zhuǎn)載等各類型的文章,如果對你有用,請推薦支持一把,給大叔寫作的動力。 |
|