久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

怎樣用JavaScript實現原型模式

瀏覽:90日期:2023-10-02 08:00:45
概述

原型模式是指原型實例指向創建對象的種類,并通過拷貝這些原型創建新的對象,是一種用來創建對象的模式,也就是創建一個對象作為另一個對象的prototype屬性;

prototype警告:學習了解原型模式前需先學習原型、原型鏈、prototype、__proto__、constructor等知識;

實現原型模式

ES5中的API:Object.create(prototype, optionalDescriptorObjects)

Object.create()方法接收兩個參數:第一個參數是__proto__對象,第二個是prototiesObject(可選,使用第二個參數可以初始化額外的其他屬性,接受字面量對象形式); 

var vehiclePrototype = { model:'保時捷', getModel: function () {console.log(’車輛模具是:’ + this.model); }};var vehicle = Object.create(vehiclePrototype,{ 'model':{value:'法拉利' }});vehicle.getModel(); //車輛模具是:法拉利

我們使用Object.create實際上是新建了一個對象vehiclePrototype,并且繼承了vehiclePrototype的方法,所以此時vehicle.__proto__ == vehiclePrototype;

第二個參數中初始化了'model'的值,將model的值初始化為了'法拉利',所以此時新創建的對象vehiclePrototype中只有一個model,值為'法拉利';

不用Object.create()實現,用prototype:

var vehiclePrototype = { init: function (carModel) {this.model = carModel || '保時捷'; }, 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中,我們先創建了一個新的構造函數,然后將該函數的原型指向vehiclePrototype,然后進行實例化該函數,最后繼承之后調用prototype上的init方法,最后將執行結果進行返回也是同樣可以實現的;

總結

原型模式在JavaScript中無處不在,其他模式中有很多也是基于prototype來實現的,所以好好學習、復習原型和原型鏈的知識很重要,重點是prototype、__proto__、constructor等關鍵屬性知識點;

以上就是怎樣用JavaScript實現原型模式的詳細內容,更多關于JavaScript原型模式的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 亚洲一区视频 | 人人玩人人干 | 国产高潮好爽受不了了夜色 | 999在线观看精品免费不卡网站 | 日韩中文一区 | 成人毛片在线观看 | 国产超碰人人模人人爽人人添 | 日韩一区二区成人 | 亚洲精品乱码久久久久久按摩观 | 一区二区中文字幕 | 午夜精品一区 | 一本色道久久综合狠狠躁篇的优点 | 男人久久天堂 | 精品一区二区在线观看 | 国产精品毛片久久久久久 | 一区二区三区视频免费在线观看 | 免费看的黄色 | 欧美精品在线一区 | 欧美黑人一级爽快片淫片高清 | 国产精品一区二区三区在线播放 | 亚洲国产精品久久人人爱 | 精品国产1区2区3区 在线国产视频 | 91资源在线| 日韩免费| 综合激情久久 | 在线成人免费视频 | 国产精品地址 | 久久中文字幕一区 | 北条麻妃一区二区三区中文字幕 | 欧美一区二区三区在线视频 | 污片在线免费看 | 啪啪tv网站免费入口 | 97久久精品| www.99re| 午夜妇女aaaa区片 | 伊人色综合网 | 日韩字幕一区 | 精品网站999www| 成人在线网站 | 国产精品一二三四区 | 久久精品色欧美aⅴ一区二区 |