|
導讀網頁的本質就是超級文本標記語言,通過結合使用其他的Web技術(如:腳本語言、公共網關接口、組件等),可以創造出功能強大的網頁。因而,超級文本標記語言是萬維網(Web)編程的基礎,也就是說萬維網是建立... 網頁的本質就是超級文本標記語言,通過結合使用其他的Web技術(如:腳本語言、公共網關接口、組件等),可以創造出功能強大的網頁。因而,超級文本標記語言是萬維網(Web)編程的基礎,也就是說萬維網是建立在超文本基礎之上的。超級文本標記語言之所以稱為超文本標記語言,是因為文本中包含了所謂“超級鏈接”點。 本篇文章給大家帶來的內容是關于JavaScript如何模擬實現new關鍵字?(附代碼),有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。最近工作太忙,快接近兩周沒更新博客,總感覺有一些事情等著自己去做,雖然工作內容對自己提升挺大,但我總覺得,一直埋著頭走路,偶爾也需要抬起頭來,看看現在和自己的期望向是否脫軌,所以周末還是選擇來星巴克寫些文字。 今天記錄 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以上,可以看出:
上面的內容有關于 JavaScript 中原型對象和原型鏈的知識,不夠清楚的同學可以查看我之前的博客。 由于 new 是 JS 的一個關鍵字,我們無法實現關鍵字,但我們可以通過函數的形式來模擬 new 關鍵字的行為。 一、基本思路知道 new 關鍵字做了哪些工作,那我們就有了模擬實現的基本思路。 /**
* 模擬實現 JavaScript new 操作符
* @param {Function} constructor [構造函數]
* @return {Object|Function|Regex|Date|Error} [返回結果]
*/
function mockNew() {
// 創建一個空對象
let resultObj = new Object();
// 取傳入的第一個參數,即構造函數,并刪除第一個參數。
let constructor = Array.prototype.shift.call(arguments);
// 類型判斷,錯誤處理
if(typeof constructor !== "function") {
throw("構造函數第一個參數應為函數");
}
// 綁定 constructor 屬性
resultObj.constructor = constructor;
// 關聯 __proto__ 到 constructor.prototype
resultObj.__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.prototype
emptyObj.__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 關鍵字的意義在于讓普通函數生成一個新對象,并將對象實例的 本文中有些地方需要一些前置知識,但是總體上理解是比較容易的。 以上就是JavaScript如何模擬實現new關鍵字?(附代碼)的詳細內容,更多請關注php中文網其它相關文章! 網站建設是一個廣義的術語,涵蓋了許多不同的技能和學科中所使用的生產和維護的網站。 |
溫馨提示:喜歡本站的話,請收藏一下本站!