Redux学习之旅十四:React-Redux代码优化

TodoList组件中没有任何的业务逻辑,只有一个render,所以可以改写为无状态组件:

import React from 'react';
import { connect } from 'react-redux';


const TodoList = (props) => {
    //js结构赋值
    let { inputValue, inputChange, clickBtn, list, deleteItem } = props;
    return (
        <div>
            <div>
                <input
                    value={inputValue}
                    onChange={inputChange}
                />
                <button
                    onClick={clickBtn}
                >
                    提交
                </button>
            </div>
            <ul>
                {
                    list.map((item, index) => {
                        return (
                            <li
                                key={index + item}
                                onClick={() => {
                                    deleteItem(index);
                                }}
                            >
                                {item}
                            </li>
                        )
                    })
                }
            </ul>
        </div>
    );
}


//state影射为props
const stateToProps = (state) => {
    return {
        inputValue: state.inputValue,
        list: state.list
    }
}
//dispatch影射为props
const dispatchToProps = (dispatch) => {
    return {
        inputChange(e) {
            let action = {
                type: 'change_input',
                value: e.target.value
            }
            dispatch(action);
        },
        clickBtn() {
            let action = {
                type: 'add_item'
            }
            dispatch(action);
        },
        deleteItem(index) {
            // console.log(index);
            let action = {
                type: 'delete_item',
                index: index
            }
            dispatch(action);
        }
    }
}

export default connect(stateToProps, dispatchToProps)(TodoList);

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值