为什么vue创建不用es6中class而是用函数

看vue源码的时候,发现在创建vue时用的是function而不是class。由于对class用的较少,真心不知道二者的区别在哪里,所以百度一下,发现网上的答案真心不清不楚:

function Vue (options) {
  if (process.env.NODE_ENV !== 'production' &&
    !(this instanceof Vue)
  ) {
    warn('Vue is a constructor and should be called with the `new` keyword')
  }
  this._init(options)
}
//它实际上就是⼀个⽤ Function 实现的类,我们只能通过new Vue 去实例化它。
//Vue 按功能把这些扩展分散到多个模块中去实现,
//⽽不是在⼀个模块⾥实现所有,
//这种⽅式是⽤ Class 难以实现的。
//这么做的好处是⾮常⽅便代码的维护和管理

然而看了以后还是觉得不明白,为什么呢?class应该也能使用prototype吧?不是也可以扩展分散吗?
经过总结,大致觉得以下几个原因:
1、function使用比较方便,call、bind、apply指向更改方便;
2、function调用方便,class必须new;
3、function创建类的原型链可枚举;
4、function有变量提升;

暂时觉得是这几点,有大神可以指点指点~~~~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值