ES5和ES6中类的区别总结


Posted in Javascript onDecember 21, 2020

类定义与调用的区别

在 ES5 中主要是通过构造函数方式和原型方式来定义一个类,但是在 ES6 新引入了 class 关键字,使之具有了正式类的能力,类(class)是ECMAScript 中新的基础性语法糖结构。虽然 ES6 类表面上看起来可以支持正式的面向对象编程,但实际上它背后使用的仍然是原型和构造函数的概念。

使用 ES5 定义一个类并调用

function Person(name, age, job) {
 this.name = "Totora";
 this.age = 19;
 this.job = "student";
 this.sayName = function() {
  console.log(this.name);
 };
}
let person = new Person();
person.sayName();

使用 ES6 定义一个类并调用

ES6中有两种定义类的方式:类声明和类表达式

class Person {
 constructor() {
  this.name = "Totora";
  this.age = 19;
  this.job = "student";
 }
 sayName() {
  console.log(this.name);
 }
}
let person = new Person();
person.sayName();
//当我们使用typeof检测Person的类型时:
console.log(typeof Person); //function,它的本质仍然是函数

在调用类时,不管是ES5还是ES6,都必须使用new操作符来进行调用,不可以直接执行。

两者区别在于:

ES5这样调用不会报错,可以正常执行(因为ES5中的类和普通函数几乎没有本质上的区别)

function Person(name, age, job) {
 this.name = "Totora";
 this.age = 19;
 this.job = "student";
 this.sayName = function() {
  console.log(this.name);
 };
}
let person = Person();
console.log(person); //undefined

ES6会报错

class Person {
 constructor() {
  this.name = "Totora";
  this.age = 19;
  this.job = "student";
 }
 sayName() {
  console.log(this.name);
 }
}
let person =Person();
console.log(person);
person.sayName(); //Class constructor Person cannot be invoked without 'new'

变量提升

通过以下对比可以发现,当用class声明类执行时会报错,说明ES6中用class定义的类无法实现变量提升。

函数受函数作用域的限制,但是类受块作用域的限制

//变量提升
let person = new Person()
function Person(name, age, job) {
 this.name = "Totora";
 this.age = 19;
 this.job = "student";
 this.sayName = function() {
  console.log(this.name);
 };
}
person.sayName(); //Totora
let person = new Person();
class Person {
 constructor() {
  this.name = "Totora";
  this.age = 19;
  this.job = "student";
 }
 sayName() {
  console.log(this.name);
 }
}
person.sayName(); // Cannot access 'Person' before initialization

class中类的构成

类可以包含构造函数方法、实例方法、获取函数、设置函数、静态类的方法。但是空的类定义照样有效

//空类定义
class Foo {}
//有构造函数的类
class Bar {
 constructor() {}
}
//有获取函数的类
class Baz {
 get myBaz() {}
}
//有静态方法的类
class Qux {
 static myQux() {}
}

class中的静态方法

可以在类上定义静态方法。静态类成员在类定义中使用static关键字作为前缀,在静态成员中,this引用类自身;

与原型成员类似,静态成员每个类上只能有一个;

static声明的静态属性和方法都可以被子类继承。

class Person {
 constructor() {
  //添加到this的所有内容都会存在于不同的实例上
  this.locate = () => console.log('instance', this);
 }
 //定义在类的原型对象上
 locate() {
  console.log('prototype', this);
 }
 //定义在类本身上
 static locate() {
  console.log('class', this);
 }
}
let p = new Person();
p.locate(); //instance Person { locate: [Function (anonymous)] }
Person.prototype.locate(); //prototype {}
Person.locate(); //class [class Person]
class Person {
 static name() {
  this.job(); //此处的this指向类
 }
 static job() {
  console.log('Totora'); //不会出现在实例中
 }
 job() {
  console.log('student');
 }
}
Person.name(); //Totora

继承

ES5中的继承实质上是先创建子类的实例对象,再将父类的方法添加到this上(Parent.apply(this)),通过原型或构造函数机制来实现

ES6的继承实际上是先创建父类的实例对象this,然后再用子类的构造函数修改this。

ES6中类之间通过extends关键字,就可以继承任何拥有[[Construct]]和原型的对象,在很大程度上,这不仅i仅可以继承一个类,也可以继承普通的构造函数(保持向后兼容)

ES6中派生类的方法可以通过super关键字引用它们的原型,这个关键字只能在派生类中使用,而且仅限于类的构造函数、实例方法和静态方法的内部。在类构造函数中使用super可以调用父类构造函数。

//ES5中的继承
function parent(a,b) {
 this.a = a;
 this.b = b;
}
function child(c) {
 this.c = c;
}
parent.call(child, 1, 2); //子级来继承父级
child.prototype = new parent(1, 2);
//ES6中的继承
class parent {
 constructor(a, b) {
  this.a = a;
  this.b = b;
 }
 parentMethods() {
  return this.a + this.b
 }
}
class child extends parent {
 constructor(a, b, c) {
  super(a, b); //通过super调用父类
  this.c = c;
 }
 childMethods() {
  return this.c + ',' + super.parentMethods() //通过super实例化调用父类
 }
}
const point = new child(1, 2, 3);
console.log(point.childMethods());

总结

到此这篇关于ES5和ES6中类区别的文章就介绍到这了,更多相关ES5和ES6类的区别内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
js中数组Array的一些常用方法总结
Aug 12 Javascript
js格式化时间和js格式化时间戳示例
Feb 10 Javascript
jQuery之字体大小的设置方法
Feb 27 Javascript
jquery中的工具使用方法$.isFunction, $.isArray(), $.isWindow()
Aug 09 Javascript
跟我学习javascript的var预解析与函数声明提升
Nov 16 Javascript
javascript实现无法关闭的弹框
Nov 27 Javascript
详解Vue中过度动画效果应用
May 25 Javascript
JS复杂判断的更优雅写法代码详解
Nov 07 Javascript
react+ant design实现Table的增、删、改的示例代码
Dec 27 Javascript
js实现石头剪刀布游戏
Oct 11 Javascript
javascript实现时钟动画
Dec 03 Javascript
webpack介绍使用配置教程详解webpack介绍和使用
Jun 25 Javascript
jQuery实现动态向上滚动
Dec 21 #jQuery
Vue组件简易模拟实现购物车
Dec 21 #Vue.js
ES6字符串的扩展实例
Dec 21 #Javascript
vue实现购物车的小练习
Dec 21 #Vue.js
Vue实现小购物车功能
Dec 21 #Vue.js
原生JS实现京东查看商品点击放大
Dec 21 #Javascript
基于javascript实现移动端轮播图效果
Dec 21 #Javascript
You might like
PHP setcookie() cannot modify header information 的解决方法
2009/01/09 PHP
PHP常用工具函数小结【移除XSS攻击、UTF8与GBK编码转换等】
2019/04/27 PHP
详解no input file specified 三种解决方法
2019/11/29 PHP
PHPExcel实现的读取多工作表操作示例
2020/04/14 PHP
javascript 面向对象,实现namespace,class,继承,重载
2009/10/29 Javascript
javascript Array.sort() 跨浏览器下需要考虑的问题
2009/12/07 Javascript
Jquery下判断Id是否存在的代码
2011/01/06 Javascript
javascript获取xml节点的最大值(实现代码)
2013/12/11 Javascript
常用的JavaScript WEB操作方法分享
2015/02/28 Javascript
Vue2实现组件props双向绑定
2016/12/02 Javascript
基于javascript实现数字英文验证码
2017/01/25 Javascript
简单实现js倒计时功能
2017/02/13 Javascript
jQuery获取table下某一行某一列的值实现代码
2017/04/07 jQuery
nodejs multer实现文件上传与下载
2017/05/10 NodeJs
详解angular笔记路由之angular-router
2017/09/12 Javascript
node使用Koa2搭建web项目的方法
2017/10/17 Javascript
js定时器实现倒计时效果
2017/11/05 Javascript
iview table高度动态设置方法
2018/03/14 Javascript
在Angular中使用JWT认证方法示例
2018/09/10 Javascript
layer提示框添加多个按钮选择的实例
2019/09/12 Javascript
微信小程序swiper使用网络图片不显示问题解决
2019/12/13 Javascript
使用Python进行二进制文件读写的简单方法(推荐)
2016/09/12 Python
Python实现PS图像抽象画风效果的方法
2018/01/23 Python
Python pyinotify日志监控系统处理日志的方法
2018/03/08 Python
python远程调用rpc模块xmlrpclib的方法
2019/01/11 Python
pandas DataFrame 删除重复的行的实现方法
2019/01/29 Python
PyQt 实现使窗口中的元素跟随窗口大小的变化而变化
2019/06/18 Python
python定间隔取点(np.linspace)的实现
2019/11/27 Python
如何使用 Python 读取文件和照片的创建日期
2020/09/05 Python
Electrolux伊莱克斯巴西商店:家用电器、小家电和配件
2018/05/23 全球购物
初中物理教学反思
2014/01/14 职场文书
教师思想作风整顿个人剖析材料
2014/10/10 职场文书
车间主任岗位职责
2015/02/03 职场文书
妈妈再爱我一次观后感
2015/06/08 职场文书
标准演讲稿格式结尾应该怎么书写?
2019/07/17 职场文书
Redis缓存-序列化对象存储乱码问题的解决
2021/06/21 Redis