static
class中的static
起因
最近在学习手写 Promise 中,产生了一些关于 class 中 static 的疑问,因此在此记录下。在声明 Promise 中,声明了两个 resolve 和 reject,一个是普通的属性,一个是 static 属性。
在 class 内部通过了 this.resolve 调用了 resolve 属性,而在外面使用 Promise.resolve()来调用了 static resolve。这两者存在什么区别。
举例
下面举个简单的例子来说明:
- 方法
class Test {
constructor() {
this.testMethod();
}
testMethod = () => {
console.log('test method');
};
}
const test = new Test(); // test
class Test2 {
constructor() {
this.testMethod();
}
static testMethod = () => {
console.log('test method');
};
}
const test2 = new Test2(); // this.testMethod is not a function
- 属性
class Test {
test = 'test';
constructor() {
console.log(this.test);
}
}
const test = new Test(); // test
class Test2 {
static test = 'test';
constructor() {
console.log(this.test);
}
}
const test2 = new Test2(); // undefined
console.log(Test2.test); // test
console.log(test2.test) // undefined
总结
在class中对于实例属性和方法与静态属性和方法的调用存在差异,对于实例的属性和方法可以通过this来调用,然后实例的属性以及方法都可以通过继承来获得,而静态的属性和方法则必须通过类名来进行调用。并且不会被继承。