es6静态属性和实例属性的区别是什么

区别:1、静态属性是类自身的属性,只能在类自身调用,而实例属性是实例对象的属性;2、实例对象无法调用静态属性,但类可调用实例属性;3、静态属性只有一种声明方法,语法“类名.属性名=值”,而实例属性有多种声明方法,例类中用“属性名=值”定义。

es6静态属性和实例属性的区别是什么

本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。

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

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

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

声明静态属性:

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

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

登录后复制

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

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

登录后复制

声明实例属性:

1,在类中定义

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

登录后复制

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

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

登录后复制

静态属性和实例属性的区别总结:

静态属性是类自身的属性,只能在类自身调用;而实例属性是实例对象的属性,可以被实例对象调用。

实例对象是无法调用到静态属性的,只能类自身调用;而类可以调用实例属性。

静态属性只有一种声明方法,而实例属性有多种声明方法。

实例属性定义在实例上,可以在构造函数的内部的this上进行定义,也可以在构造函数实例化以后的实例上进行定义。

静态属性,定义在构造函数之上的属性。可通过构造函数直接访问。

【相关推荐:javascript视频教程、web前端】

以上就是es6静态属性和实例属性的区别是什么的详细内容,更多请关注【创想鸟】其它相关文章!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

点点赞赏,手留余香

给TA打赏
共0人
还没有人赞赏,快来当第一个赞赏的人吧!
    编程技术

    es6有什么新加的东西

    2025-3-11 20:36:42

    编程技术

    es6怎么判断值是否为空

    2025-3-11 20:36:49

    0 条回复 A文章作者 M管理员
    欢迎您,新朋友,感谢参与互动!
      暂无讨论,说说你的看法吧
    个人中心
    购物车
    优惠劵
    今日签到
    私信列表
    搜索