ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

javascript – 在react组件中写一个类之外的函数

2019-06-27 14:24:20  阅读:181  来源: 互联网

标签:javascript ecmascript-6 reactjs es6-class


我见过这样的代码

function abc(){
  return 'abc'
}
class MyComponent extends React.Component {
    static abc = abc;
    render() { return <h1>{this.abc}</h1>; }
}

其中函数abc在react类之外定义.我不知道为什么作者这样做,为什么不能在课堂上这样做呢?

解决方法:

这些是ES6 static methods,并不是React独有的.它们是组件类的成员,而不是组件的实例.它们并没有在React中广泛使用,但它们可能很有用.它甚至在React docs中提到:

Sometimes it’s useful to define a static method on a React component.
For example, Relay containers expose a static method getFragment to
facilitate the composition of GraphQL fragments.

它们可以用作Component的公共成员,由它的所有实例共享.为了给你一个想法,其他static members of a React class是displayName和defaultProps.

另请参见Static methods in React.正如您所看到的,在很多情况下您将使用静态方法.

标签:javascript,ecmascript-6,reactjs,es6-class
来源: https://codeday.me/bug/20190627/1305511.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有