日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

JavaScript专题之模拟实现new

發布時間:2024/4/14 javascript 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JavaScript专题之模拟实现new 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
本文共 1230 字,讀完只需 5 分鐘

寫在前面

最近工作太忙,快接近兩周沒更新博客,總感覺有一些事情等著自己去做,雖然工作內容對自己提升挺大,但我總覺得,一直埋著頭走路,偶爾也需要抬起頭來,看看現在和自己的期望向是否脫軌,所以周末還是選擇來星巴克寫些文字。

今天記錄 JavaScript 中 new 關鍵字的模擬實現,當我們在模擬實現某個語言行為之前,應該想想這個行為都做了哪些事情,通過實踐,最后也能更加掌握知識點,這就是很多面試題都會問到模擬實現的原因,目的是為了考察候選人知識的深度。

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 創建并返回了一個新對象,是構造函數的實例
  • 對象的實例的構造函數屬性其實是構造函數的原型對象的 constructor 屬性
  • 對象實例的 __proto__ 關聯到構造函數的原型對象
  • 上面的內容有關于 JavaScript 中原型對象和原型鏈的知識,不夠清楚的同學可以查看我之前的博客。

    由于 new 是 JS 的一個關鍵字,我們無法實現關鍵字,但我們可以通過函數的形式來模擬 new 關鍵字的行為。

    一、基本思路

    知道 new 關鍵字做了哪些工作,那我們就有了模擬實現的基本思路。

    /*** 模擬實現 JavaScript new 操作符* @param {Function} constructor [構造函數]* @return {Object|Function|Regex|Date|Error} [返回結果]*/ function mockNew() {// 創建一個空對象let resultObj = new Object();// 取傳入的第一個參數,即構造函數,并刪除第一個參數。// 關于為什么要用 Array.prototype.shift.call 的形式,見之前的博客文章 《JavaScript之arguments》let constructor = Array.prototype.shift.call(arguments);// 類型判斷,錯誤處理if(typeof constructor !== "function") {throw("構造函數第一個參數應為函數");}// 綁定 constructor 屬性resultObj.constructor = constructor;// 關聯 __proto__ 到 constructor.prototyperesultObj.__proto__ = constructor.prototype;// 將構造函數的 this 指向返回的對象constructor.apply(resultObj, arguments);// 返回對象return resultObj; }function Person(name) {this.name = name; }var person = mockNew(Person, "jayChou");console.log(person);// constructor: ? Person(name) // name: "jayChou" // __proto__: Object

    基本思路正確! 所以我們完成了 new 關鍵字的初步模擬。伙伴們可以自己動手敲一下,每句代碼自己是否都能理解。

    二、處理返回值

    構造函數也是函數,有不同類型返回值。有時候構造函數會返回指定的對象內容,所以要對這部分進行處理。

    /*** 模擬實現 JavaScript new 操作符* @param {Function} constructor [構造函數]* @return {Object|Function|Regex|Date|Error} [返回結果]*/ function mockNew() {// 創建一個空對象let emptyObj = new Object();// 取傳入的第一個參數,即構造函數,并刪除第一個參數。// 關于為什么要用 Array.prototype.shift.call 的形式,見之前的博客文章 《JavaScript之arguments》let constructor = Array.prototype.shift.call(arguments);// 類型判斷,錯誤處理if(typeof constructor !== "function") {throw("構造函數第一個參數應為函數");}// 綁定 constructor 屬性emptyObj.constructor = constructor;// 關聯 __proto__ 到 constructor.prototypeemptyObj.__proto__ = constructor.prototype;// 將構造函數的 this 指向返回的對象let resultObj = constructor.apply(emptyObj, arguments);// 返回類型判斷, 如果是對象,則返回構造函數返回的對象if (typeof resultObj === "object") {return resultObj}// 返回對象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

    當返回值返回了一個自定義對象后,模擬 new 函數就返回該自定義對象。

    總結

    JavaScript new 關鍵字的意義在于讓普通函數生成一個新對象,并將對象實例的 __proto__ 關聯到函數的 prototype 對象。

    本文中有些地方需要一些前置知識,但是總體上理解是比較容易的。如果有迷惑的地方,可以翻看我之前的博客文章

    歡迎關注我的個人公眾號“謝南波”,專注分享原創文章。

    總結

    以上是生活随笔為你收集整理的JavaScript专题之模拟实现new的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。