登录  /  注册

es6继承和es5继承的区别是什么

青灯夜游
发布: 2021-09-03 16:08:55
原创
6780人浏览过

es5和es6继承的区别: es5的继承是通过原型或构造函数机制实现的;它先创建子类,再实例化父类并添加到子类this中。 es6先创建父类,再实例化子集中通过调用super方法访问父级后,再通过修改this实现继承。

es6继承和es5继承的区别是什么

本教程操作环境:windows7系统、ECMAScript 5&&ECMAScript 6版、Dell G3电脑。

es6继承和es5继承的区别

  • ES5的继承实质上是先创建子类的实例对象,然后再将父类的方法添加到this上(Parent.apply(this)).

  • ES6的继承机制完全不同,实质上是先创建父类的实例对象this(所以必须先调用父类的super()方法),然后再用子类的构造函数修改this。

  • ES5的继承是通过原型或构造函数机制来实现。

  • ES6通过class关键字定义类,里面有构造方法,类之间通过extends关键字实现继承。子类必须在constructor方法中调用super方法,否则新建实例报错。因为子类没有自己的this对象,而是继承了父类的this对象,然后对其进行加工。如果不调用super方法,子类得不到this对象。

注意super关键字指代父类的实例,即父类的this对象。

注意:在子类构造函数中,调用super后,才可使用this关键字,否则报错。

1、在es5中的继承:

	function parent(a,b){
	    this a = a;
	    this b = b;
	}
	function child(c){
	    this c = c
	};
登录后复制

通过子集去继承父级:

parent.call(child,1,2)
登录后复制

而去看call的底层方法可知,继承的过程是通过prototype属性

child.prototype = new parent(1,2);
登录后复制

由此可知,ES5继承的实质是先创建了子类元素child的的实例对象,然后再把父类元素parent的原型对象中的属性赋值给子类元素child的实例对象里面,从而实现继承

2、ES6中的继承

在传统JS中,生成对象是通过创建构造函数,然后定义生成对象

function parent(a,b){
    this.a = a;
    this.b = b;
}
登录后复制

然后通过prototype增加对应所需方法或属性

parent.prototype.methods = function(){
    return 'this is test methods';
}
parent.prototype.attr = 'this is test attr‘;
登录后复制

而ES6中引入了类的概念,也就是class。通过关键词class去定义对象。

class是个关键词,语言糖,这样能更清晰的读懂所创建的对象,

通过属性constructor来接收控制方法传入的参数,如果不写这个属性,默认是没有参数的

class parent{
    curstructor(a,b){
        this.a = a;
        this.b = b;
    }
}
登录后复制

ES6中的继承是基于class类之间继承的。通过关键词extends实现。

通过super实例化调用父类

	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);
	    this.c = c;
	  }
	  childMethods(){
	    return this.c + ',' + super.parentMethods()
	  }
	}
	const point = new child(1,2,3);
	alert(point.childMethods());
登录后复制

上面的代码,是一套简单的ES6父子类继承。

相信已经看出来了,虽明显的区别就是在于ES6中,激活父组件的是super方法,而不是新建实例化,也就是说,父类的实例对象是先创建出来的,调用后,再去修改子类的构造函数中的this完善原型对象。

总结:

ES5和ES6继承最大的区别就是在于:

  • ES5先创建子类,在实例化父类并添加到子类this中

  • ES6先创建父类,在实例化子集中通过调用super方法访问父级后,在通过修改this实现继承

【推荐学习:javascript视频教程

以上就是es6继承和es5继承的区别是什么的详细内容,更多请关注php中文网其它相关文章!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号