react创建组件的3种不同方式的区别 createClass ES6Class Statelessfunction

Stateless Function V.S. ES6 Classes

上代码,

//来一个stateless function,用ES6的语法写
const SimpleComponent = ({text,onClick}) => (
    <div onClick={onClick}>
       Your text is {text}. Click to say.
    </div>
)

如果换成ES6 Classes的写法:

//原谅我不能写出更简单的案例了,`ES6 Classes`的写法就是会复杂些
class SimpleComponent extends React.Component {

  //这个是构造函数,绑定事件,初始化state
  constructor() {
    super();
    this.state = {
      text: 'say something!'
    };
    this.handleClick = this.handleClick.bind(this);
  }

  //上面那个函数的实现
  handleClick() {
    this.setState({liked: !this.state.liked});
  }

  //熟悉的render
  render() {
    return (
      <div onClick={this.handleClick}>
        Your text is {text}. Click to say.
      </div>
    );
  }
}

区别是:

用ES6 Classes方式写的组件,有this,以及this.statethis.setState等属性和方法,
纯函数写的组件只能依赖外界传入的参数,不能拥有自己的state

引用官方文档:

“尽量让你的组件保持无状态。
一个通常的做法是,创建一些无状态的组件,只是简单的把传入数据渲染出来。
然后在最顶层用一个带有状态(state)的组件给这些组件传递数据”

一个有状态的父组件,带领一堆没有状态的子组件,把它的state传递给子组件,这也是redux的方式

另外

官方推荐使用stateless function,这是最近推出的方式,在性能上更有优越性

而createClass是这三个里面最老的api,不过我觉得createClass更方便,不用写construct


参考文献 :
1.官方文档
2.James K Nelson的博客文章

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值