成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

ES6—類的實(shí)現(xiàn)原理

Heier / 1434人閱讀

摘要:對(duì)應(yīng)轉(zhuǎn)碼將提出這個(gè)方面即是判斷的是否有指向的對(duì)象。同樣再轉(zhuǎn)碼中,找到了對(duì)應(yīng)的確保為的關(guān)聯(lián)到給添加這個(gè)屬性設(shè)置的內(nèi)置與相關(guān)聯(lián)可以看出背后是通過的原型鏈實(shí)現(xiàn)的。其中對(duì)應(yīng)的轉(zhuǎn)碼其中實(shí)現(xiàn)了的原理。顯示綁定的內(nèi)置到,即在中執(zhí)行原型鏈上關(guān)聯(lián)的屬性。

ES6篇

一段符合ES6語法的代碼

    class a{
      constructor(y,z){
        this.y =y;
        this.z =z;
      }
      render(){
        console.log(1)
      }
    }
    
    class b extends a{
      constructor(m,n){
        super();
        this.m=m;
        this.n=n;
      }
      
      render(){
        console.log(2);
      }
    }

我在babel官網(wǎng)上輸入,查看轉(zhuǎn)碼(),代碼長(zhǎng)很多,從中找出關(guān)鍵點(diǎn):

class

constructor

extend

super

class

聲明class class a(){}
查看對(duì)應(yīng)轉(zhuǎn)碼 var a = function(){return a}()
可以看出聲明一個(gè)class就是通過創(chuàng)建并執(zhí)行一個(gè)匿名函數(shù),在這個(gè)匿名函數(shù)中聲明function a,最后返回a。

constructor
 
 constructor(y,z){
        this.y =y;
        this.z =z;
     }
     

對(duì)應(yīng)轉(zhuǎn)碼:

function a(y, z) {
        _classCallCheck(this, a);

        this.y = y;
        this.z = z;
    }
    

_classCallCheck(this,a)提出

function _classCallCheck(instance, Constructor) { 
    if (!(instance instanceof Constructor)) { 
        throw new TypeError("Cannot call a class as a function");
     } 
}

這個(gè)方面即是判斷this的[[prototype]]是否有指向a.prototype的對(duì)象。即是判斷原本是不是有a這個(gè)function。??感覺解釋的不好。
然后再在a(本質(zhì)是function,但可以被稱作class)中聲明屬性y,z。
接下來,在class a中有一個(gè)render方法,

_createClass(a, [{
    key: "render",
    value: function render() {
      console.log(1);
    }
}]);

通過_createClass方法,可以給a添加render方法。

_createClass提出來看。

var _createClass = function () { 
    // 給對(duì)象添加屬性
    function defineProperties(target, props) {
     for (var i = 0; i < props.length; i++) { 
         var descriptor = props[i]; 
         descriptor.enumerable = descriptor.enumerable || false; //默認(rèn)不可枚舉
         descriptor.configurable = true;//可配置修改屬性
         if ("value" in descriptor) descriptor.writable = true;
         Object.defineProperty(target, descriptor.key, descriptor);//給target添加屬性
      } 
    }
    // 返回函數(shù)
    return function (Constructor, protoProps, staticProps) { 
        if (protoProps) defineProperties(Constructor.prototype, protoProps); 
        if (staticProps) defineProperties(Constructor, staticProps); 
        return Constructor; 
    }; 
}();//立即執(zhí)行

由上推斷es6給class添加的屬性、方法背后是es5對(duì)給對(duì)象添加屬性的方法。

extend

同樣再轉(zhuǎn)碼中,找到了對(duì)應(yīng)的_inherits(b, _a)

function _inherits(subClass, superClass) { 
    // 確保superClass為function
    if (typeof superClass !== "function" && superClass !== null) { 
        throw new TypeError("Super expression must either be null or a function, not " + typeof superClass);
    } 
    // subClass.prototype的[[prototype]]關(guān)聯(lián)到superClass superClass.prototype
    // 給subClass添加constructor這個(gè)屬性
    subClass.prototype = Object.create(superClass && superClass.prototype, { 
        constructor: { 
            value: subClass, 
            enumerable: false, 
            writable: true, 
            configurable: true 
        } 
    });
    // 設(shè)置subclass的內(nèi)置[[prototype]]與superClass相關(guān)聯(lián)
    if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;
}

可以看出extend背后是通過js的原型鏈實(shí)現(xiàn)的。
其中在class b extends a中要將a傳入b中。

super

其中對(duì)應(yīng)的轉(zhuǎn)碼:

function b(m, n) {
    _classCallCheck(this, b);

    var _this = _possibleConstructorReturn(this, (b.__proto__ || Object.getPrototypeOf(b)).call(this));

    _this.m = m;
    _this.n = n;
    return _this;
  }

其中_possibleConstructorReturn實(shí)現(xiàn)了super的原理。

function _possibleConstructorReturn(self, call) {
  if (!self) {
      throw new ReferenceError("this hasn"t been initialised - super() hasn"t been called"); 
  } 
  //顯示綁定b的內(nèi)置[[prototype]]到this,即在b中執(zhí)行b原型鏈上關(guān)聯(lián)的屬性。
  return call && (typeof call === "object" || typeof call === "function") ? call : self; 
}

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/81578.html

相關(guān)文章

  • ES6類以及繼承的實(shí)現(xiàn)原理

    摘要:中通過關(guān)鍵字,定義類經(jīng)過轉(zhuǎn)碼之后可以看到類的底層還是通過構(gòu)造函數(shù)去創(chuàng)建的。在中,構(gòu)造函數(shù)是可以直接運(yùn)行的,比如。如果你有靜態(tài)屬性,會(huì)直接添加到構(gòu)造函數(shù)上。不是很好理解,可以通過下面的方式理解是一個(gè)實(shí)例,是構(gòu)造方法的原型。 ES6中通過class關(guān)鍵字,定義類 class Parent { constructor(name,age){ this.name = na...

    Warren 評(píng)論0 收藏0
  • javascript之模擬類繼承

    摘要:歡迎關(guān)注我的博客正文讓我來構(gòu)造函數(shù)其實(shí),模擬一個(gè)類的方式非常的簡(jiǎn)單構(gòu)造函數(shù)。我們先來看一個(gè)例子這里通過構(gòu)造函數(shù)模擬出來的類,其實(shí)和其他語言的類行為上是基本一致的,唯一的區(qū)別就是它不具備私有方法。 前言 ES6時(shí)代的來臨,使得類繼承變得如此的圓滑。但是,你有思考過ES6的類繼承模式嗎?如何去實(shí)現(xiàn)它呢? 類繼承對(duì)于JavaScript來說,實(shí)現(xiàn)方式與Java等類語言大不相同。熟悉JavaS...

    Jochen 評(píng)論0 收藏0
  • es6類和繼承的實(shí)現(xiàn)原理

    摘要:類的實(shí)現(xiàn)轉(zhuǎn)換前轉(zhuǎn)換后可見的底層依然是構(gòu)造函數(shù)調(diào)用方法判斷當(dāng)前函數(shù)調(diào)用前是否有關(guān)鍵字。若構(gòu)造函數(shù)前面沒有則構(gòu)造函數(shù)的不會(huì)不出現(xiàn)在的原型鏈上,返回。典型的寄生繼承用父類構(gòu)造函數(shù)的創(chuàng)建一個(gè)空對(duì)象,并將這個(gè)對(duì)象指向子類構(gòu)造函數(shù)的。代表父類構(gòu)造函數(shù)。 在閱讀文章之前,您至少需要對(duì)JavaScript原型繼承有一定了解,如果覺得有所欠缺,可以先了解下我這篇文章:https://segmentfau...

    haitiancoder 評(píng)論0 收藏0
  • JavaScript 工作原理之十五-類和繼承及 Babel 和 TypeScript 代碼轉(zhuǎn)換探秘

    摘要:使用新的易用的類定義,歸根結(jié)底也是要?jiǎng)?chuàng)建構(gòu)造函數(shù)和修改原型。首先,它把構(gòu)造函數(shù)當(dāng)成單獨(dú)的函數(shù)且包含類屬性集。該節(jié)點(diǎn)還儲(chǔ)存了指向父類的指針引用,該父類也并儲(chǔ)存了構(gòu)造函數(shù),屬性集和及父類引用,依次類推。 原文請(qǐng)查閱這里,略有刪減,本文采用知識(shí)共享署名 4.0 國(guó)際許可協(xié)議共享,BY Troland。 本系列持續(xù)更新中,Github 地址請(qǐng)查閱這里。 這是 JavaScript 工作原理的第...

    GeekGhc 評(píng)論0 收藏0
  • JavaScript 工作原理之十五-類和繼承及 Babel 和 TypeScript 代碼轉(zhuǎn)換探秘

    摘要:使用新的易用的類定義,歸根結(jié)底也是要?jiǎng)?chuàng)建構(gòu)造函數(shù)和修改原型。首先,它把構(gòu)造函數(shù)當(dāng)成單獨(dú)的函數(shù)且包含類屬性集。該節(jié)點(diǎn)還儲(chǔ)存了指向父類的指針引用,該父類也并儲(chǔ)存了構(gòu)造函數(shù),屬性集和及父類引用,依次類推。 原文請(qǐng)查閱這里,略有刪減,本文采用知識(shí)共享署名 4.0 國(guó)際許可協(xié)議共享,BY Troland。 本系列持續(xù)更新中,Github 地址請(qǐng)查閱這里。 這是 JavaScript 工作原理的第...

    BigNerdCoding 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<