摘要:對(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(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中。
其中對(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)鍵字,定義類經(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...
摘要:歡迎關(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...
摘要:類的實(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...
摘要:使用新的易用的類定義,歸根結(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 工作原理的第...
摘要:使用新的易用的類定義,歸根結(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 工作原理的第...
閱讀 1127·2021-11-15 18:00
閱讀 2840·2021-09-22 15:18
閱讀 1998·2021-09-04 16:45
閱讀 781·2019-08-30 15:55
閱讀 3902·2019-08-30 13:10
閱讀 1374·2019-08-30 11:06
閱讀 2011·2019-08-29 12:51
閱讀 2326·2019-08-26 13:55