无状态组件

前面我们写了UI组件 和 容器组件。

还有一种组件:无状态组件。

无状态组件其实就是一个函数。普通的组件,是js 中的类,这个类还有一些生命周期函数。所以无状态组件的性能比普通组件要好。

当一个组件,只有一个render 函数的时候,就可以被修改成无状态组件。

一般,在做UI组件的时候,它没有逻辑操作,只是渲染的话。我们可以使用无状态组件定义它。

这是之前的UI组件,代码。

import React, {Component} from 'react';
import 'antd/dist/antd.css';
import { Input, Button, List } from 'antd';


class TodoListUI extends Component {
  render() {
    return (
      <div style={{marginTop: '10px',marginLeft: '10px'}}>
        <Input
          value={this.props.inputValue}
          placeholder="todo info"
          style={{width: 300, marginRight: '10px'}}
          onChange={this.props.handleInputChange}
        />
        <Button
          type="primary"
          onClick={this.props.handleBtnClick}
        >提交</Button>
        <List
          style={{marginTop: '10px', width: '300px'}}
          bordered
          dataSource={this.props.list}
          renderItem={(item, index) => (<List.Item onClick={() => {this.props.handleItemClick(index)}}>{item}</List.Item>)}
        />
      </div>
    )
  }
}

export default TodoListUI;

下面是将它改成无状态组件的代码。(容器组件那边,代码完全不用改)

import React, {Component} from 'react';
import 'antd/dist/antd.css';
import { Input, Button, List } from 'antd';

const TodoListUI = (props) => {
  return (
    <div style={{marginTop: '10px',marginLeft: '10px'}}>
      <Input
        value={props.inputValue}
        placeholder="todo info"
        style={{width: 300, marginRight: '10px'}}
        onChange={props.handleInputChange}
      />
      <Button
        type="primary"
        onClick={props.handleBtnClick}
      >提交</Button>
      <List
        style={{marginTop: '10px', width: '300px'}}
        bordered
        dataSource={props.list}
        renderItem={(item, index) => (<List.Item onClick={() => {props.handleItemClick(index)}}>{item}</List.Item>)}
      />
    </div>
  )
}


export default TodoListUI;

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值