ES6中class类用法实例浅析
本文实例讲述了ES6中class类用法。分享给大家供大家参考,具体如下:
类语法是ES6中新增的一个亮点特色。我们熟悉的JavaScript终于迎来了真正意义上的类。在之前,想要通过javascript来实现类,通常会采用如下构造函数的模式:
functionPerson(name,age,job){
this.name=name;
this.age=age;
this.job=job;
this.friends=['Shelby','Court'];
}
Person.prototype={
constructor:Person,
sayName:function(){
document.write(this.name);
}
}
然后通过实例化调用:
varperson1=newPerson('lf',23,'softwareengineer');
person1.sayName();
下面看看使用ES6的类如何处理:
classPerson{
constructor(name,age,job){
this.name=name;
this.age=age;
this.job=job;
this.friends=[‘Shelby','Court']
}
sayName(){
document.write(this.name);
}
}
可以看到简便了不少。
Class语法的推出可不光光是为了简化噢,还有很多关键字。比如:
static关键字用来定义类的静态方法,静态方法是指那些不需要对类进行实例化,使用类名就可以直接访问的方法。静态方法经常用来作为工具函数:
classPoint{
constructor(x,y){
this.x=x;
this.y=y;
}
staticdistance(a,b){
constdx=a.x-b.x;
constdy=a.y-b.y;
returnMath.sqrt(dx*dx+dy*dy);
}
}
constp1=newPoint(5,5);
constp2=newPoint(10,10);
console.log(Point.distance(p1,p2));
但是需要注意的是,ES6中不能直接定义静态成员变量,但是我们可以通过另外的方式来实现:
staticgetbaseUrl(){
return'www.baidu.com'
}
在类语法推出之前,我们想要实现继承,必须通过prototype来指定对象,而现在我们可以通过extends关键字来实现继承:
classAnimal{
constructor(name){
this.name=name;
}
speak(){
console.log(this.name+'makesanoise.');
}
}
classDogextendsAnimal{
speak(){
console.log(this.name+'barks.');
}
}
但是需要注意的一点就是,继承的原理还是在利用prototype这点没有变,只不过extends裹了一层语法糖而已。
希望本文所述对大家ECMAScript程序设计有所帮助。