成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

前端百題斬——從驗證點到手撕New操作符

開發(fā) 前端
new真的做了這幾步嗎?秉承著“實踐是檢驗真理的唯一標準”的原則,下面將這幾個關鍵點進行逐一驗證。

[[405765]]

18.1 基礎

new的作用是通過構造函數來創(chuàng)建一個實例對象,該實例與原型和構造函數之間的關系如下圖所示:

18.2 new過程中發(fā)生了什么

當一個構造函數new的過程到底發(fā)生了什么?簡要概述主要分為以下幾個步驟:

  • 一個新對象被創(chuàng)建;
  • 該對象的__ proto __屬性指向該構造函數的原型,即Fn.prototype;
  • 將執(zhí)行上下文(this)綁定到新創(chuàng)建的對象中;
  • 如果構造函數有返回值(對象或函數),那么這個返回值將取代第一步中新創(chuàng)建的對象。

new真的做了這幾步嗎?秉承著“實踐是檢驗真理的唯一標準”的原則,下面將這幾個關鍵點進行逐一驗證。

  1. function Fun() { 
  2.     this.a = 10; 
  3.     this.b = 20; 
  4.     this.method1 = () => { 
  5.         return this.a + this.b; 
  6.     } 
  7.     this.method2 = () => { 
  8.         return this; 
  9.     } 
  10.  
  11. Fun.prototype = { 
  12.     method2: () => { 
  13.         console.log('原型上的method1被訪問'); 
  14.     } 

18.2.1 驗證點1——新對象被創(chuàng)建

驗證點1是新對象被創(chuàng)建,其實這個里面有兩層含義:

new之后返回的內容是一個對象

  1. const fun = new Fun(); 
  2. console.log(fun); //  { a: 10, b: 20, method1: [Function] } 
  3. console.log(typeof(fun)); // object 

通過打印其內容,并通過typeof進行驗證,其返回內容確實是一個對象。

每次返回的都是一個新創(chuàng)建的對象

  1. const fun1 = new Fun(); 
  2. const fun2 = new Fun(); 
  3. console.log(fun1 === fun2); // false 

通過創(chuàng)建兩個實例,通過判斷兩個實例不相等,則證明確實每次返回的是一個新的對象。

18.2.2 驗證點2——該對象可訪問原型上的屬性和方法

驗證點2是新創(chuàng)建的實例可訪問原型上的屬性和方法,驗證該關鍵點只需要訪問原型上的方法即可實現(xiàn),若原型上的方法能夠被正常訪問,則表示該驗證點通過,負責不通過。

  1. const fun3 = new Fun(); 
  2. fun3.method3(); // 原型上的method3被訪問 

通過驗證,原型上的方法確實能夠被訪問。

18.2.3 驗證點3——this指向

驗證this指向只需要將this指向打印出來即可。

  1. const fun4 = new Fun(); 
  2. console.log(fun4.method2()); // { a: 10, b: 20, method1: [Function], method2: [Function] } 
  3. console.log(fun4.method2() === fun4); // true 

18.2.4 驗證點4——構造函數有返回值的處理邏輯

一個函數的返回值可以有多種,例如:string、boolean、number、Object、function等,下面我們驗證一些內容,看構造函數有不同的返回值,其實例為何值。

返回值為string

  1. function Fun() { 
  2.     this.a = 10; 
  3.     this.b = 20; 
  4.     return 'test'
  5. Fun.prototype = { 
  6.     method: () => { 
  7.         console.log('原型上的method被訪問'); 
  8.     } 
  9.  
  10. const fun = new Fun(); 
  11. console.log(fun); // { a: 10, b: 20 } 

觀察其最終結果,字符串沒有沒正常返回,返回值是一個新的實例。

返回值為Object

  1. function Fun() { 
  2.     this.a = 10; 
  3.     this.b = 20; 
  4.     return { 
  5.         c: 30 
  6.     }; 
  7. Fun.prototype = { 
  8.     method: () => { 
  9.         console.log('原型上的method被訪問'); 
  10.     } 
  11.  
  12. const fun = new Fun(); 
  13. console.log(fun); // { c: 30 } 

觀察其結果,返回值是函數中返回的對象,則表征當構造函數返回值為對象時,會返回其對象,不返回實例化后的內容。

返回值為function

  1. function Fun() { 
  2.     this.a = 10; 
  3.     this.b = 20; 
  4.     return function() { 
  5.         this.d = 40; 
  6.     }; 
  7. Fun.prototype = { 
  8.     method: () => { 
  9.         console.log('原型上的method被訪問'); 
  10.     } 
  11.  
  12. const fun = new Fun(); 
  13. console.log(fun); // [Function

返回函數的效果和返回對象的效果一致。

通過不斷嘗試總結,可以得出以下結論:

構造函數的返回值為基本類型,其返回值是實例化后的對象,不受返回值的影響;

構造函數的返回值是引用類型,其返回值即為new之后的返回值。

18.3 實現(xiàn)一個new

介紹了這么多,已經理解了new時發(fā)生的事情并經過了驗證,下面就手動實現(xiàn)一個自己的new函數。

  1. function myNew(Fn, ...args) { 
  2.     // 一個新的對象被創(chuàng)建 
  3.     const result = {}; 
  4.     // 該對象的__proto__屬性指向該構造函數的原型 
  5.     if (Fn.prototype !== null) { 
  6.         Object.setPrototypeOf(result, Fn.prototype); 
  7.     } 
  8.  
  9.     // 將執(zhí)行上下文(this)綁定到新創(chuàng)建的對象中 
  10.     const returnResult = Fn.apply(result, args); 
  11.     // 如果構造函數有返回值(對象或函數),那么這個返回值將取代第一步中新創(chuàng)建的對象。 
  12.     if ((typeof returnResult === 'object' || typeof returnResult === 'function') && returnResult !== null) { 
  13.         return returnResult; 
  14.     } 
  15.     return result; 

小試牛刀

  1. function Fun() { 
  2.     this.a = 10; 
  3.     this.b = 20; 
  4. Fun.prototype = { 
  5.     method: () => { 
  6.         console.log('原型上的method被訪問'); 
  7.     } 
  8. const fun1 = new Fun(); 
  9. console.log(fun1); // { a: 10, b: 20 } 
  10. const fun2 = myNew(Fun); 
  11. console.log(fun2); // { a: 10, b: 20 } 

 

責任編輯:武曉燕 來源: 執(zhí)鳶者
相關推薦

2021-12-03 06:59:23

操作符驗證點屬性

2021-06-09 07:01:30

前端CallApply

2022-10-08 07:49:55

New操作符函數

2021-10-19 22:23:05

typeof方式Instanceof

2021-05-09 22:00:59

TypeofInstanceof運算符

2021-05-16 19:23:11

引用類型包裝

2021-07-26 06:57:58

重繪回流前端

2021-05-30 19:02:59

變量對象上下文

2021-07-14 07:00:53

瀏覽器技巧前端

2021-10-18 09:01:01

前端賦值淺拷貝

2021-08-04 06:56:49

HTTP緩存前端

2021-05-12 07:04:55

Js變量方式

2021-11-19 09:01:09

防抖節(jié)流前端

2021-06-04 07:04:29

閉包JavaScript函數

2021-07-26 05:01:55

瀏覽器渲染流程

2021-06-28 07:12:28

賦值淺拷貝深拷貝

2021-10-31 18:59:55

Python操作符用法

2010-07-14 14:55:07

Perl操作符

2009-08-19 17:26:28

C# 操作符

2021-05-19 07:02:42

JS對象方法
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 免费av播放| 久久国产精品偷 | 欧美日本高清 | 亚洲免费观看视频 | 国产伦精品一区二区三区精品视频 | 亚洲成人一区 | 日韩欧美亚洲 | 密色视频| 亚洲精品乱码久久久久久按摩 | 欧美在线色 | 成人免费看片 | 91精品久久久 | 精品国产亚洲一区二区三区大结局 | 日韩精品无码一区二区三区 | 欧美性成人| 亚洲伊人精品酒店 | 亚洲国产成人精品女人久久久 | 亚洲国产精品久久 | 亚洲精品丝袜日韩 | 精品久久久久久 | 日韩精品一区二区三区视频播放 | 99一区二区 | 欧美成人一级 | 日本精品国产 | 9久久婷婷国产综合精品性色 | 午夜视频精品 | 精品一区二区三区日本 | 在线观看亚洲一区二区 | 综合第一页 | 91在线精品视频 | 91精品国产自产在线老师啪 | 亚洲成人免费视频 | 成人在线观| 亚洲性在线 | 狠狠爱一区二区三区 | 国产在线一区二区 | 欧美日韩精品免费 | 亚洲综合大片69999 | 精品国产18久久久久久二百 | 久久出精品| 国产二区在线播放 |