前言
和其他高級語言一樣 javascript 中也有 new 運(yùn)算符,我們知道 new 運(yùn)算符是用來實(shí)例化一個(gè)類,從而在內(nèi)存中分配一個(gè)實(shí)例對象。 但在 javascript 中,萬物皆對象,為什么還要通過 new 來產(chǎn)生對象? 本文將帶你一起來探索 javascript 中 new 的奧秘...
要?jiǎng)?chuàng)建 Person 的新實(shí)例,必須使用 new 操作符。
以這種方式調(diào)用構(gòu)造函數(shù)實(shí)際上會(huì)經(jīng)歷以下 4個(gè)步驟:
(1) 創(chuàng)建一個(gè)新對象;
(2) 將構(gòu)造函數(shù)的作用域賦給新對象(因此 this 就指向了這個(gè)新對象) ;
(3) 執(zhí)行構(gòu)造函數(shù)中的代碼(為這個(gè)新對象添加屬性) ;
(4) 返回新對象。
new 操作符
在有上面的基礎(chǔ)概念的介紹之后,在加上new操作符,我們就能完成傳統(tǒng)面向?qū)ο蟮腸lass + new的方式創(chuàng)建對象,在JavaScript中,我們將這類方式成為Pseudoclassical。
基于上面的例子,我們執(zhí)行如下代碼
var obj = new Base();
這樣代碼的結(jié)果是什么,我們在Javascript引擎中看到的對象模型是:
new操作符具體干了什么呢?其實(shí)很簡單,就干了三件事情。
var obj = {}; obj.proto = Base.prototype; Base.call(obj);
第一行,我們創(chuàng)建了一個(gè)空對象obj
第二行,我們將這個(gè)空對象的proto成員指向了Base函數(shù)對象prototype成員對象
第三行,我們將Base函數(shù)對象的this指針替換成obj,然后再調(diào)用Base函數(shù),于是我們就給obj對象賦值了一個(gè)id成員變量,這個(gè)成員變量的值是”base”,關(guān)于call函數(shù)的用法。
如果我們給Base.prototype的對象添加一些函數(shù)會(huì)有什么效果呢?
例如代碼如下:
Base.prototype.toString = function() { return this.id; }
那么當(dāng)我們使用new創(chuàng)建一個(gè)新對象的時(shí)候,根據(jù)proto的特性,toString這個(gè)方法也可以做新對象的方法被訪問到。于是我們看到了:
構(gòu)造子中,我們來設(shè)置‘類'的成員變量(例如:例子中的id),構(gòu)造子對象prototype中我們來設(shè)置‘類'的公共方法。于是通過函數(shù)對象和Javascript特有的proto與prototype成員及new操作符,模擬出類和類實(shí)例化的效果。
相信看了本文案例你已經(jīng)掌握了方法,更多精彩請關(guān)注Gxl網(wǎng)其它相關(guān)文章!
推薦閱讀:
vue父組件調(diào)用子組件有哪些方法
vue全局組件與局部組件使用案例分析詳解
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com