JS ES6中Class类实现原理是什么
Admin 2022-10-13 群英技术资讯 621 次浏览
JavaScript ES6之前的还没有Class类的概念,生成实例对象的传统方法是通过构造函数。
例如:
function Mold(a,b){ this.a=a; this.b=b; } Mold.prototype.count=function(){ return this.a+this.b; }; let sum=new Mold(1,2); console.log(sum.count()) //3
这中写法跟传统的面向对象语言差异较大,写起来也比较繁杂。
ES6提供了更加接近其他语言的写法,引入了Class(类)的概念,作为对象的模板,可以通过class关键字,定义类(类似python、java等);
当然ES6的大部分功能再ES5都能实现,ES6的class可以看作是一个语法糖,只是新的class定义类的写法让对象原型的写法更加简单明了、更接近与面向对象的编程思想。与上面ES5写的类使用ES6实现,例如:
class Mold{ constructor(a,b){ this.a=a; this.b=b; } count(){ return this.a+this.b; } } let sum=new Mold(1,2); console.log(sum.count()) //3
这里ES6的类,只需用class定义,并且类的方法不需要用function定义;还有ES6的constructor方法,代表这该类的构造方法;并且它的this关键字指向着实例对象。这里ES5的构造函数Mold,相当于ES6Mold类的constructor方法。
constructor
ES6实例对象的构造函数就是该类本身;并且当我们new 类名()就是执行了constructor这个函数。
例如:
class Mold{ constructor(){ console.log("aaa") } } let m=new Mold();// aaa console.log(m.constructor===Mold);//true
上面代码Mold类的constructor,实例化对象时执行默认constructor;
任何对象都有构造函数,并且构造函数与当前对象的类是相同;
例如:
let arr=new Array(); console.log(arr.constructor===Array);//true let str=new String(); console.log(str.constructor===String);//true let obj=new Object(); console.log(obj.constructor===Object);//true
2. 类的继承 extends
继承父类后,子类会继承父类所有的方法和属性(包括静态方法和属性)
如果子类没有定义constructor方法,会默认被添加该方法
任何子类都有constructor方法;
例如:
//class 类名 extends 被继承的类{} Class Father{ constructor(){ } sum(){ console.log("abc"); } static fn(){ console.log("hello") } } Class Son extends Father{ } let s=new Son(); s.sum()//abc,继承了父类的sum()方法 Son.fn()//hello 继承了父类的静态方法fn()
继承后的子类方法的三种处理:
1). 完全继承,不需要重写这个方法,子类执行继承方法内容与父类相同
2). 重写覆盖,只需要在这个类中重写这个方法就可以覆盖继承过来的内容
3). 加工,子类可以用super调用父类的方法或属性进行加工,再加上子类自己的方法和属性
3. super
调用父类的构造函数直接使用super(),并且可以传参;
子类的构造函数中,只有调用了super之后才可以使用this关键字,否则会报错;
例如:
//super.父类函数(); class Father{ constructor(){ console.log("bbb"); } } class Son extends Father{ constructor(x){ this.x=x;//ReferenceError,报错 super(); this.x=x;//正确 } } let sum=new Son();//bbb
4. 类的static静态
在属性或方法前面使用 static定义类的静态属性和方法;
所有的静态属性和静态方法都不能通过实例化的对象调用;
需要通过类来调用,静态属性和静态方法是类的专属属性和方法,和实例化对象无关,比如数组和数学方法中的:Array.from();Math.random()。
例如:
class Mold{ static x=0; y=1; static fn1(){ console.log("aaa") } fn2(){ console.log("bbb"); } } let m=new Mold(); console.log(m.x,m.y);//undefined , 1 m.fn1(); // TypeError m.fn2(); // bbb //需要通过类来调用 Mold.fn1(); //aaa console.log(Mold.x);//0
静态的使用场景:
一般静态的方法是用来解决一系列该类型的方法;
解决具体类型的方法,不是解决某个具体对象的方法
静态属性,一般用于存储该类型的一系列通用的属性变量
这种存储,在类创建的时候就已经变成全局的了,可在任何地方调用,并且不会被自动销毁
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要为大家详细介绍了vue实现搜索小功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
Window对象可以用来打开浏览器,调整浏览器的位置、大小等等功能。Window对象可以处理框架和框架之间的关系,通过这种关系在一个框架中处理另一
用React如何实现星星评分组件?评分插件在一些购物应用上常常会使用的到,例如用星星评分的效果,那么这一效果是怎样做的呢?下面给大家分享一下用React实现星星评分插件的实例,感兴趣的朋友可以参考。
这篇文章主要介绍了Vue 实现双向绑定的四种方法,非常不错,具有参考借鉴价值,需要的朋友参考下吧,希望能够给你带来帮助
node.js中有中文乱码怎么办?很多朋友都有遇到过node.Js中出现中文乱码的问题,那么遇到这样的情况我们该怎样解决呢?下面就给大家来分享一个方法,需要的朋友可以参考。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008