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 相关文章推荐
jQuery学习笔记[1] jQuery中的DOM操作
Dec 03 Javascript
Jquery获得控件值的三种方法总结
Feb 13 Javascript
基于javascript实现的搜索时自动提示功能
Dec 26 Javascript
node.js调用C++开发的模块实例
Jul 03 Javascript
利用jQuery.Validate异步验证用户名是否存在(推荐)
Dec 09 Javascript
jQueryUI 拖放排序遇到滚动条时有可能无法执行排序的小bug及解决方案
Dec 19 Javascript
vue开发调试神器vue-devtools使用详解
Jul 13 Javascript
基于VUE.JS的移动端框架Mint UI的使用
Oct 11 Javascript
node.js通过axios实现网络请求的方法
Mar 05 Javascript
JS简单实现动态添加HTML标记的方法示例
Apr 08 Javascript
JS实现点击拉拽轮播图pc端移动端适配
Sep 05 Javascript
基于node.js实现爬虫的讲解
Feb 18 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后台程序与Javascript的两种交互方式
2009/10/25 PHP
php中将时间差转换为字符串提示的实现代码
2011/08/08 PHP
PHP大小写问题:函数名和类名不区分,变量名区分
2013/06/17 PHP
PHP去除字符串最后一个字符的三种方法实例
2017/03/01 PHP
thinkphp5框架路由原理与用法详解
2020/02/11 PHP
Jquery Ajax学习实例6 向WebService发出请求,返回DataSet(XML) 异步调用
2010/03/18 Javascript
setInterval与clearInterval的使用示例代码
2014/01/28 Javascript
jquery序列化表单以及回调函数的使用示例
2014/07/02 Javascript
JavaScript设计模式之外观模式实例
2014/10/10 Javascript
DOM基础教程之使用DOM
2015/01/19 Javascript
jQuery满屏焦点图左右滚动特效代码分享
2015/09/07 Javascript
基于jQuery实现二级下拉菜单效果
2016/02/01 Javascript
JavaScript异步上传图片文件的实例代码
2017/07/04 Javascript
bootstrap多层模态框滚动条消失的问题
2017/07/21 Javascript
JavaScript实现兼容IE6的收起折叠与展开效果实例
2017/09/20 Javascript
Angular4绑定html内容出现警告的处理方法
2017/11/03 Javascript
详解Node.js模板引擎Jade入门
2018/01/19 Javascript
JS apply用法总结和使用场景实例分析
2020/03/14 Javascript
python绘制双柱形图代码实例
2017/12/14 Python
python获取指定字符串中重复模式最高的字符串方法
2018/06/29 Python
Django开发的简易留言板案例详解
2018/12/04 Python
python 命名规范知识点汇总
2020/02/14 Python
Python字符串split及rsplit方法原理详解
2020/06/29 Python
Python .py生成.pyd文件并打包.exe 的注意事项说明
2021/03/04 Python
介绍一下gcc特性
2015/10/31 面试题
介绍JAVA 中的Collection FrameWork(及如何写自己的数据结构)
2014/10/31 面试题
计算机应用专业推荐信
2013/11/13 职场文书
早餐连锁店计划书
2014/01/08 职场文书
教师档案管理制度
2014/01/23 职场文书
三下乡活动方案
2014/01/31 职场文书
总经理工作职责范文
2014/03/14 职场文书
化工操作工岗位职责
2014/04/29 职场文书
2014年学校德育工作总结
2014/12/05 职场文书
2014年学校后勤工作总结
2014/12/06 职场文书
2015年学校消防安全工作总结
2015/10/14 职场文书
党员干部学法用法心得体会
2016/01/21 职场文书