怎樣用JavaScript實(shí)現(xiàn)原型模式
概述
原型模式是指原型實(shí)例指向創(chuàng)建對(duì)象的種類,并通過拷貝這些原型創(chuàng)建新的對(duì)象,是一種用來創(chuàng)建對(duì)象的模式,也就是創(chuàng)建一個(gè)對(duì)象作為另一個(gè)對(duì)象的prototype屬性;
prototype警告:學(xué)習(xí)了解原型模式前需先學(xué)習(xí)原型、原型鏈、prototype、__proto__、constructor等知識(shí);
實(shí)現(xiàn)原型模式
ES5中的API:Object.create(prototype, optionalDescriptorObjects)
Object.create()方法接收兩個(gè)參數(shù):第一個(gè)參數(shù)是__proto__對(duì)象,第二個(gè)是prototiesObject(可選,使用第二個(gè)參數(shù)可以初始化額外的其他屬性,接受字面量對(duì)象形式);
var vehiclePrototype = { model:"保時(shí)捷", getModel: function () { console.log('車輛模具是:' + this.model); } }; var vehicle = Object.create(vehiclePrototype,{ "model":{ value:"法拉利" } }); vehicle.getModel(); //車輛模具是:法拉利
我們使用Object.create實(shí)際上是新建了一個(gè)對(duì)象vehiclePrototype,并且繼承了vehiclePrototype的方法,所以此時(shí)vehicle.__proto__ == vehiclePrototype;
第二個(gè)參數(shù)中初始化了"model"的值,將model的值初始化為了"法拉利",所以此時(shí)新創(chuàng)建的對(duì)象vehiclePrototype中只有一個(gè)model,值為"法拉利";
不用Object.create()實(shí)現(xiàn),用prototype:
var vehiclePrototype = { init: function (carModel) { this.model = carModel || "保時(shí)捷"; }, getModel: function () { console.log('車輛模具是:' + this.model); } }; function vehicle(model) { function F() { }; F.prototype = vehiclePrototype; var f = new F(); f.init(model); return f; } var car = vehicle('法拉利'); car.getModel(); // 車輛模具是:法拉利
上述代碼中,我們可以看到核心是在vehicle中,我們先創(chuàng)建了一個(gè)新的構(gòu)造函數(shù),然后將該函數(shù)的原型指向vehiclePrototype,然后進(jìn)行實(shí)例化該函數(shù),最后繼承之后調(diào)用prototype上的init方法,最后將執(zhí)行結(jié)果進(jìn)行返回也是同樣可以實(shí)現(xiàn)的;
總結(jié)
原型模式在JavaScript中無處不在,其他模式中有很多也是基于prototype來實(shí)現(xiàn)的,所以好好學(xué)習(xí)、復(fù)習(xí)原型和原型鏈的知識(shí)很重要,重點(diǎn)是prototype、__proto__、constructor等關(guān)鍵屬性知識(shí)點(diǎn);
以上就是怎樣用JavaScript實(shí)現(xiàn)原型模式的詳細(xì)內(nèi)容,更多關(guān)于JavaScript原型模式的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- js面向?qū)ο笾R妱?chuàng)建對(duì)象的幾種方式(工廠模式、構(gòu)造函數(shù)模式、原型模式)
- 詳解js產(chǎn)生對(duì)象的3種基本方式(工廠模式,構(gòu)造函數(shù)模式,原型模式)
- JavaScript設(shè)計(jì)模式之原型模式分析【ES5與ES6】
- JavaScript創(chuàng)建對(duì)象方式總結(jié)【工廠模式、構(gòu)造函數(shù)模式、原型模式等】
- 深入了解js原型模式
- javascript設(shè)計(jì)模式 – 原型模式原理與應(yīng)用實(shí)例分析
- Javascript設(shè)計(jì)模式之原型模式詳細(xì)
- JavaScript設(shè)計(jì)模式之原型模式詳情
相關(guān)文章
JavaScript 存在陷阱 刪除某一區(qū)域所有節(jié)點(diǎn)
實(shí)現(xiàn)功能:刪除某一區(qū)域中所有節(jié)點(diǎn)。2010-05-05IE6與IE7中,innerHTML獲取param的區(qū)別
最近,在用一些web編輯器,發(fā)現(xiàn)插入一段mp3后,查看源代碼,object標(biāo)簽中的param都被刪除。下面我演示給大家看看。2009-03-03JS實(shí)現(xiàn)簡(jiǎn)單路由器功能的方法
這篇文章主要介紹了JS實(shí)現(xiàn)簡(jiǎn)單路由器功能的方法,基于javascript模擬簡(jiǎn)單路由編碼的相關(guān)技巧,需要的朋友可以參考下2015-05-05promise和co搭配生成器函數(shù)方式解決js代碼異步流程的比較
這篇文章主要介紹了promise和co搭配生成器函數(shù)方式解決js代碼異步流程的比較,在es6中引入的原生Promise為js的異步回調(diào)問題帶來了一個(gè)新的解決方式co模塊搭配Generator函數(shù)的同步寫法,更是將js的異步回調(diào)帶了更優(yōu)雅的寫法。感興趣的小伙伴們可以參考一下2018-05-05巧用js提交表單輕松解決一個(gè)頁面有多個(gè)提交按鈕
使用js提交表單想必大家都會(huì),如果要實(shí)現(xiàn)一個(gè)頁面有多個(gè)提交按鈕,你會(huì)嗎?下面有個(gè)不錯(cuò)的示例,大家可以感受下2013-11-11