欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript中new操作符的原理與實現(xiàn)詳解

 更新時間:2022年10月25日 15:55:59   作者:來碗鹽焗星球  
你知道new嗎?你知道new的實現(xiàn)原理嗎?你能手寫new方法嗎?不要擔心,這篇文件就來帶大家深入了解一下JavaScript中的new操作符,感興趣的小伙伴可以學習一下

一、new做了哪些事

先看看new的使用場景:

// 1、創(chuàng)建一個構造函數(shù)
function Vehicle(name, price) {
    this.name = name
    this.price = price
}
?
// 2、new一個實例對象
let truck = new Vehicle()
console.log(truck); //Vehicle { name: undefined, price: undefined }
console.log(Object.prototype.toString.call(truck)); //[object Object]
?
// 傳入?yún)?shù)
let car = new Vehicle('car', '¥9999999')
console.log(car);
//Vehicle { name: 'car', price: '¥9999999' }

司空見慣的代碼,爛熟于心的寫法,那你知道new具體做了哪些事情嘛?從上述代碼可以看出,一個構造函數(shù)使用new操作符調用的時候,會生成一個具有構造函數(shù)相同屬性的新對象。是不是很奇怪?明明Vehicle是構造函數(shù):

console.log(typeof Vehicle); //function

然而,經(jīng)過new的一番操作后,它的實例化是一個對象!?。ew到底做了哪些事情呢?對于這個例子,我們可以概括為以下事情:

?
    // 第一件:在構造函數(shù)內部,創(chuàng)建一個this對象
    let this = {
        name = name,
        price = price
    }
?
    // 第二件:返回this對象
    return this;
?
    // 第三件:給this對象的屬性賦值
    this.name = name
    this.price = price

很抽象,看不懂。。。進一步剖析如下:

function Person(name, gender) {
    console.log('賦值前的this=', this); //賦值前的this= Person {}
    this.name = name
    this.gender = gender
    console.log('賦值后的this=', this); //賦值后的this= Person { name: '小灰灰', gender: 'boy' }
}
?
let child = new Person('小灰灰', 'boy')//Person { name: '小灰灰', gender: 'boy' }
console.log(child);

由以上代碼可以看出,

第一:在構造函數(shù)內部有一個空的this對象,通過new操作符,會創(chuàng)建生成一個全新的對象(實例對象)。

第二:實例對象會執(zhí)行[[Prototype]]( .proto)鏈接,并且實例對象的this會指向構造函數(shù)的this(實例對象會綁定函數(shù)調用的this)。通過new創(chuàng)建的實例對象最終被[[Prototype]]( .proto)鏈接到構造函數(shù)的Prototype對象上。也就是說,實例對象的隱式原型===構造函數(shù)的顯示原型

二、返回不同類型時有哪些表現(xiàn)

創(chuàng)建一個構造函數(shù)X,通過new操作符,實例化X得到實例化對象x,打印x,一定會是X{...}這個對象嘛?當構造函數(shù)內部有返回值,并且返回的是不同類型的值,打印的結果又會是怎么樣呢?

function Student(id, name) {
    this.id = id
    this.name = name
?
    // 返回基本類型的值時:返回的結果依然是對象Student {name:xxx,age:xxx}
    // return null   //Student { id: '1001', name: 'cat' }
    // return undefined //Student { id: '1001', name: 'cat' }
    // return 123        //Student { id: '1001', name: 'cat' }
    // return 'hello world'   //Student { id: '1001', name: 'cat' }
    // return true  //Student { id: '1001', name: 'cat' }
    // return false  //Student { id: '1001', name: 'cat' }
    //return Symbol('abc')  //Student { id: '1001', name: 'cat' }
?
    // 返回引用類型時:
    //返回空對象時:返回的結果是空對象
    // return {}  //{}
    //返回函數(shù)時,返回的結果是函數(shù)
    return function() {} //[Function (anonymous)]
    // return [] //[]
    // return new Date() //2022-10-24T04:44:18.581Z
    // return new Error() //Error...
}
?
let student = new Student('1001', 'cat')
console.log(student); //構造函數(shù)內部返回不同類型的值時,這里的打印結果是一樣的嗎?

三、手寫new的實現(xiàn)原理

思路:new的實現(xiàn)原理核心是new做了哪些事情。

總結:

(1)通過new操作符調用構造函數(shù),會返回一個全新的對象,這個對象的屬性是構造函數(shù)的參數(shù)。

若構造函數(shù)內部有返回值,且返回值是基本數(shù)據(jù)類型(number|string|null|undefined|Symbol|boolean),則實例對象的返回結果是原本的對象;

若返回值是引用數(shù)據(jù)類型(Object|Array|Function|Date|RegExp|Error),則實例對象的返回的結果就是引用類型對應的值。

(2)通過new操作符創(chuàng)建的實例對象的隱式原型會掛載到構造函數(shù)的顯示原型上。實例對象.proto==構造函數(shù).prototype。

(3)通過new操作符創(chuàng)建的實例對象的this會綁定調用函數(shù)的this 請看如下代碼:

// new的實現(xiàn)原理
function newPerson() {
    // 先return一個對象
    var obj = {};
    
    var constructor = Array.prototype.shift.call(arguments); //把數(shù)組的shift方法借給constructor使用
    
    // 實例對象的隱式原型===構造函數(shù)的顯示原型
    obj._proto_ = constructor.prototype;
    var result = constructor.apply(obj, arguments);
    return typeof result === 'object' && result != 'null' ? result : obj;
}
?
let p = newPerson(Person, 'hunny')
console.log(p); //{ _proto_: {}, name: 'hunny', age: undefined }

以上就是JavaScript中new操作符的原理與實現(xiàn)詳解的詳細內容,更多關于JavaScript new操作符的資料請關注腳本之家其它相關文章!

相關文章

  • js+html制作簡單驗證碼

    js+html制作簡單驗證碼

    這篇文章主要為大家詳細介紹了js結合html制作簡單驗證碼的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • js如何實現(xiàn)input的賦值

    js如何實現(xiàn)input的賦值

    這篇文章主要介紹了js如何實現(xiàn)input的賦值問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • vant uploader實現(xiàn)上傳圖片拖拽功能(設為封面)

    vant uploader實現(xiàn)上傳圖片拖拽功能(設為封面)

    這篇文章主要介紹了vant uploader實現(xiàn)上傳圖片拖拽功能(設為封面),這個功能在日常生活中經(jīng)常會用到,操作非常方便,今天通過實例代碼介紹實現(xiàn)過程,需要的朋友可以參考下
    2021-10-10
  • js不間斷滾動的簡單實現(xiàn)

    js不間斷滾動的簡單實現(xiàn)

    下面小編就為大家?guī)硪黄猨s不間斷滾動的簡單實現(xiàn)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • 一步一步教你寫帶圖片注釋的淡入淡出插件(四)

    一步一步教你寫帶圖片注釋的淡入淡出插件(四)

    第三部分的效果已經(jīng)基本上滿足大部分的需求了。所以這一部分呢,只能算是加分項。廢話不多說了,還是繼續(xù)博文吧。
    2010-10-10
  • JS寫滑稽笑臉運動效果

    JS寫滑稽笑臉運動效果

    這篇文章主要介紹了JS寫滑稽笑臉運動效果,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • SWFObject 2.1以上版本語法介紹

    SWFObject 2.1以上版本語法介紹

    用SWFObject 插入flash,好處多多,代碼簡潔,不會出現(xiàn)微軟的“單擊此處以激活控件”的提示(據(jù)可靠消息,這個是微軟惹的官司,其結果是害苦了用戶)。
    2010-07-07
  • Weex開發(fā)之地圖篇的具體使用

    Weex開發(fā)之地圖篇的具體使用

    這篇文章主要介紹了Weex開發(fā)之地圖篇的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-10-10
  • 自定義PC微信掃碼登錄樣式寫法

    自定義PC微信掃碼登錄樣式寫法

    這篇文章主要介紹了自定義PC微信掃碼登錄樣式的寫法以及做了代碼分析,需要的朋友學習下吧。
    2017-12-12
  • 使用JavaScript平移和縮放圖像的示例代碼

    使用JavaScript平移和縮放圖像的示例代碼

    平移和縮放是查看圖像時常用的功能,我們可以放大圖像以查看更多細節(jié),進行圖像編輯,Dynamsoft Document Viewer是一個用于此目的的SDK,它為文檔圖像提供了一組查看器,在本文中,我們將演示如何使用它來平移和縮放圖像,需要的朋友可以參考下
    2024-08-08

最新評論