es6 javascript的class的静态方法、属性和实例属性
来源:互联网 发布:樱桃初夏网络剧 编辑:程序博客网 时间:2024/06/08 12:00
类相当于实例的原型, 所有在类中定义的方法, 都会被实例继承。 如果在一个方法前, 加上static关键字, 就表示该方法不会被实例继承, 而是直接通过类来调用, 这就称为“ 静态方法”。
class Foo {static classMethod() {return 'hello';}}Foo.classMethod() // 'hello'var foo = new Foo();foo.classMethod()// TypeError: foo.classMethod is not a function上面代码中, Foo类的classMethod方法前有static关键字, 表明该方法是一个静态方法, 可以直接在Foo类上调用( Foo.classMethod()), 而不是在Foo类的实例上调用。 如果在实例上调用静态方法, 会抛出一个错误, 表示不存在该方法。
父类的静态方法, 可以被子类继承。
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();
静态属性指的是 Class 本身的属性, 即Class.propname, 而不是定义在实例对象( this) 上的属性。
class Foo {}Foo.prop = 1;Foo.prop // 1上面的写法为Foo类定义了一个静态属性prop。
目前, 只有这种写法可行, 因为 ES6 明确规定, Class 内部只有静态方法, 没有静态属性。
// 以下两种写法都无效class Foo {// 写法一prop: 2// 写法二static prop: 2}Foo.prop // undefinedES7 有一个静态属性的提案, 目前 Babel 转码器支持。
这个提案对实例属性和静态属性, 都规定了新的写法。
( 1) 类的实例属性
类的实例属性可以用等式, 写入类的定义之中。
class MyClass {myProp = 42;constructor() {console.log(this.myProp); // 42}}上面代码中, myProp就是MyClass的实例属性。 在MyClass的实例上, 可以读取这个属性。
以前, 我们定义实例属性, 只能写在类的constructor方法里面。
class ReactCounter extends React.Component {constructor(props) {super(props);this.state = {count: 0};}}上面代码中, 构造方法constructor里面, 定义了this.state属性。
有了新的写法以后, 可以不在constructor方法里面定义。
class ReactCounter extends React.Component {state = {count: 0};}这种写法比以前更清晰。
为了可读性的目的, 对于那些在constructor里面已经定义的实例属性, 新写法允许直接列出。
class ReactCounter extends React.Component {constructor(props) {super(props);this.state = {count: 0};}state;}(2) 类的静态属性
类的静态属性只要在上面的实例属性写法前面, 加上static关键字就可以了。
class MyClass {
static myStaticProp = 42;
constructor() {
console.log(MyClass.myProp); // 42
}
}
同样的, 这个新写法大大方便了静态属性的表达。
// 老写法class Foo {}Foo.prop = 1;// 新写法class Foo {static prop = 1;}上面代码中, 老写法的静态属性定义在类的外部。 整个类生成以后, 再生成静态属性。 这样让人很容易忽略这个静态属性, 也不符合相关代码应该放在一起的代码组织原则。 另外, 新写法是显式声明( declarative), 而不是赋值处理, 语义更好。
0 0
- es6 javascript的class的静态方法、属性和实例属性
- ES6 类(Class)基本用法和静态属性+方法详解
- ES6 类(Class)基本用法和静态属性方法详解
- es6 javascript的map数据结构的实例的属性和操作方法、遍历方法
- es6 javascript属性的遍历
- js中静态方法(属性)、实例方法(属性)、内部方法(属性)和原型的一点见解
- JavaScript的Prototype属性 静态方法属性 存档
- JavaScript的属性和方法
- es6中Class的静态方法详解
- Python Class的实例属性/类属性
- es6 javascript的Class 的 Generator 方法
- es6 javascript属性的可枚举性
- js属性和方法的可见性:私有属性(方法),实例属性(方法),类属性(方法)
- JavaScript函数的实例属性和类属性
- 静态导入类的属性和方法
- ES6-对象的扩展-方法name属性
- es6新增属性和方法
- es6 javascript的Proxy 实例的方法
- 利用百度开发者中心完成的 第三方登录
- 类帮助文件
- 第四章上机3-5
- 第十六周项目1---验证算法(排序)
- 1209
- es6 javascript的class的静态方法、属性和实例属性
- TCP echo test
- C# 输入验证
- POJ 1862 Stripies 笔记
- MemCache缓存multiget hole详解
- 16 - 12 - 10 关键路径代码(C++)
- 百度地图4.1_1开发教程(9)poi搜索功能
- makefile的编写
- android 弹出一个广告