es6中类中的静态属性、实例属性、静态方法、实例方法的个人理解

静态的就是不会被实例继承的,是属于类自身的,实例继承不了,也调用不了,跟作用域一样

静态属性、静态方法:就是类自身的属性和方法,只能在类自身调用,实例对象是无法调用到静态属性和方法的,只能类自身调用,当然子类也可以调用父类的静态属性和方法;

实例属性、实例方法:就是实例可以调用的属性和方法,记住实例是无法调用类的静态属性和方法的,但是类可以调用实例属性和实例方法;

 

声明静态属性

就和普通的Object添加属性一样,object.a = a;(目前唯一一种方法);有人提议在类内部加static关键字,但是还没实现

class F{};
F.b="父类的静态属性";//给F类加静态方法

声明静态方法:在方法前加上static关键字

复制代码
class Foo {
  static bar () {//静态方法  静态方法中的this指向类本身而不是实例
    this.baz();
  }
  static baz () {//静态方法
    console.log('hello');
  }
}
 
Foo.bar() // hello
new Foo().bar();//实例调用不了,会报错
复制代码

声明实例属性

1,在类中定义

复制代码
class MyClass {
  myProp = 42;
 
  constructor(props) {
    console.log(this.myProp); // 42
  this.name=props.name
} } //上面代码中,myProp就是MyClass的实例属性。在MyClass的实例上,可以读取这个属性。
复制代码

2,在constructor中定义(react中经典写法)

复制代码
class ReactCounter extends React.Component {
  constructor(props) {
    super(props);//可以让子类继承
    this.state = {
      count: 0
    };
  }
}
 
//等价于
class ReactCounter extends React.Component {
  state = {
    count: 0
  };
}
复制代码

声明实例方法

class Student {
    hello() {
        alert('Hello, '+ '!');
    }
}
new Student().hello();

 

 

posted @   古墩古墩  Views(726)  Comments(0Edit  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示