当前位置: 移动技术网 > IT编程>网页制作>CSS > es6 Class的静态方法实例讲解

es6 Class的静态方法实例讲解

2018年02月03日  | 移动技术网IT编程  | 我要评论

Class 的静态方法

类相当于实例的原型,所有在类中定义的方法,都会被实例继承。如果在一个方法前,加上static关键字,就表示该方法不会被实例继承,而是直接通过类来调用,这就称为“静态方法”。

class Foo {

  static classMethod() {

    return 'hello';

  }

}

Foo.classMethod() // 'hello'

var foo = new Foo();

foo.classMethod()

// TypeError: foo.classMethod is not a function

上面代码中,ES6

Foo类的classMethod方法前有static关键字,表明该方法是一个静态方法,可以直接在Foo类上调用(Foo.classMethod()),而不是在Foo类的实例上调用。如果在实例上调用静态方法,会抛出一个错误,表示不存在该方法。

注意,如果静态方法包含this关键字,这个this指的是类,而不是实例。

class Foo {

  static bar () {

    this.baz();

  }

  static baz () {

    console.log('hello');

  }

  baz () {

    console.log('world');

  }

}

Foo.bar() // hello

上面代码中,静态方法bar调用了this.baz,这里的this指的是Foo类,而不是Foo的实例,等同于调用Foo.baz。另外,从这个例子还可以看出,静态方法可以与非静态方法重名。

父类的静态方法,可以被子类继承。

class Foo {

  static classMethod() {

    return 'hello';

  }

}

class Bar extends Foo {

}

Bar.classMethod() // 'hello'

上面代码中,父类Foo有一个静态方法,子类Bar可以调用这个方法。

静态方法也是可以从super对象上调用的。

class Foo {

  static classMethod() {

    return 'hello';

  }

}

class Bar extends Foo {

  static classMethod() {

    return super.classMethod() + ', too';

  }

}

Bar.classMethod() // "hello, too"

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网