這篇文章給大家分享的是有關(guān)JavaScript模擬實(shí)現(xiàn)new關(guān)鍵字的方法的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧。
站在用戶的角度思考問(wèn)題,與客戶深入溝通,找到金川網(wǎng)站設(shè)計(jì)與金川網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:網(wǎng)站設(shè)計(jì)制作、做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名申請(qǐng)、網(wǎng)頁(yè)空間、企業(yè)郵箱。業(yè)務(wù)覆蓋金川地區(qū)。
最近工作太忙,快接近兩周沒(méi)更新博客,總感覺(jué)有一些事情等著自己去做,雖然工作內(nèi)容對(duì)自己提升挺大,但我總覺(jué)得,一直埋著頭走路,偶爾也需要抬起頭來(lái),看看現(xiàn)在和自己的期望向是否脫軌,所以周末還是選擇來(lái)星巴克寫些文字。
今天記錄 JavaScript 中 new 關(guān)鍵字的模擬實(shí)現(xiàn),當(dāng)我們?cè)谀M實(shí)現(xiàn)某個(gè)語(yǔ)言行為之前,應(yīng)該想想這個(gè)行為都做了哪些事情,通過(guò)實(shí)踐,最后也能更加掌握知識(shí)點(diǎn),這就是很多面試題都會(huì)問(wèn)到模擬實(shí)現(xiàn)的原因,目的是為了考察候選人知識(shí)的深度。
function Person(name) { this.name = name; } var person = new Person('jayChou'); typeof(person) // "object" person instanceof Person // true person.__proto__ === Person.prototype // true person.constructor === Person // true person.constructor === Person.prototype.constructor // true
以上,可以看出:
new 創(chuàng)建并返回了一個(gè)新對(duì)象,是構(gòu)造函數(shù)的實(shí)例
對(duì)象的實(shí)例的構(gòu)造函數(shù)屬性其實(shí)是構(gòu)造函數(shù)的原型對(duì)象的 constructor 屬性
對(duì)象實(shí)例的 __proto__ 關(guān)聯(lián)到構(gòu)造函數(shù)的原型對(duì)象
上面的內(nèi)容有關(guān)于 JavaScript 中原型對(duì)象和原型鏈的知識(shí),不夠清楚的同學(xué)可以查看我之前的博客。
由于 new 是 JS 的一個(gè)關(guān)鍵字,我們無(wú)法實(shí)現(xiàn)關(guān)鍵字,但我們可以通過(guò)函數(shù)的形式來(lái)模擬 new 關(guān)鍵字的行為。
知道 new 關(guān)鍵字做了哪些工作,那我們就有了模擬實(shí)現(xiàn)的基本思路。
/** * 模擬實(shí)現(xiàn) JavaScript new 操作符 * @param {Function} constructor [構(gòu)造函數(shù)] * @return {Object|Function|Regex|Date|Error} [返回結(jié)果] */ function mockNew() { // 創(chuàng)建一個(gè)空對(duì)象 let resultObj = new Object(); // 取傳入的第一個(gè)參數(shù),即構(gòu)造函數(shù),并刪除第一個(gè)參數(shù)。 let constructor = Array.prototype.shift.call(arguments); // 類型判斷,錯(cuò)誤處理 if(typeof constructor !== "function") { throw("構(gòu)造函數(shù)第一個(gè)參數(shù)應(yīng)為函數(shù)"); } // 綁定 constructor 屬性 resultObj.constructor = constructor; // 關(guān)聯(lián) __proto__ 到 constructor.prototype resultObj.__proto__ = constructor.prototype; // 將構(gòu)造函數(shù)的 this 指向返回的對(duì)象 constructor.apply(resultObj, arguments); // 返回對(duì)象 return resultObj; } function Person(name) { this.name = name; } var person = mockNew(Person, "jayChou"); console.log(person); // constructor: ? Person(name) // name: "jayChou" // __proto__: Object
基本思路正確! 所以我們完成了 new 關(guān)鍵字的初步模擬?;锇閭兛梢宰约簞?dòng)手敲一下,每句代碼自己是否都能理解。
構(gòu)造函數(shù)也是函數(shù),有不同類型返回值。有時(shí)候構(gòu)造函數(shù)會(huì)返回指定的對(duì)象內(nèi)容,所以要對(duì)這部分進(jìn)行處理。
/** * 模擬實(shí)現(xiàn) JavaScript new 操作符 * @param {Function} constructor [構(gòu)造函數(shù)] * @return {Object|Function|Regex|Date|Error} [返回結(jié)果] */ function mockNew() { // 創(chuàng)建一個(gè)空對(duì)象 let emptyObj = new Object(); // 取傳入的第一個(gè)參數(shù),即構(gòu)造函數(shù),并刪除第一個(gè)參數(shù)。 // 關(guān)于為什么要用 Array.prototype.shift.call 的形式,見(jiàn)之前的博客文章 《JavaScript之a(chǎn)rguments》 let constructor = Array.prototype.shift.call(arguments); // 類型判斷,錯(cuò)誤處理 if(typeof constructor !== "function") { throw("構(gòu)造函數(shù)第一個(gè)參數(shù)應(yīng)為函數(shù)"); } // 綁定 constructor 屬性 emptyObj.constructor = constructor; // 關(guān)聯(lián) __proto__ 到 constructor.prototype emptyObj.__proto__ = constructor.prototype; // 將構(gòu)造函數(shù)的 this 指向返回的對(duì)象 let resultObj = constructor.apply(emptyObj, arguments); // 返回類型判斷, 如果是對(duì)象,則返回構(gòu)造函數(shù)返回的對(duì)象 if (typeof resultObj === "object") { return resultObj } // 返回對(duì)象 return emptyObj; } function Person(name) { this.name = name; return { name: this.name, age: 40 } } var person = mockNew(Person, "jayChou"); console.log(person); // {name: "jayChou", age: 40} // age: 40 // name: "jayChou" // __proto__: Object
當(dāng)返回值返回了一個(gè)自定義對(duì)象后,模擬 new 函數(shù)就返回該自定義對(duì)象。
JavaScript new 關(guān)鍵字的意義在于讓普通函數(shù)生成一個(gè)新對(duì)象,并將對(duì)象實(shí)例的 __proto__
關(guān)聯(lián)到函數(shù)的 prototype 對(duì)象。
感謝各位的閱讀!關(guān)于JavaScript模擬實(shí)現(xiàn)new關(guān)鍵字的方法就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
文章題目:JavaScript模擬實(shí)現(xiàn)new關(guān)鍵字的方法
URL地址:http://chinadenli.net/article42/gediec.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、網(wǎng)站維護(hù)、全網(wǎng)營(yíng)銷推廣、建站公司、網(wǎng)站設(shè)計(jì)、域名注冊(cè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)