react与redux的简单结合

javascript 代码

import React, {Component} from 'react';
import {createStore, bindActionCreators} from 'redux';

function reducer(state, action) {
    if (typeof state === 'undefined') return {name: '', num: 0};
    switch(action.type) {
        case 'changeName':
            return Object.assign({}, state, action.payload);
        case 'access':
            return Object.assign({}, state, {num: ++state.num});
        default:
            return state;
    }
}

const store = createStore(reducer, {name: '', num: 0});

let actions = {
    changeName(name) {
        return {
            type: 'changeName',
            payload: {name}
        };
    },
    assess() {
        return {
            type: 'access'
        };
    }
}

/*将UI事件和派发action巧妙的结合了起来*/
actions = bindActionCreators(actions, store.dispatch);

class Test extends Component {
    constructor(props) {
        super(props);
        this.state = {
            name: '',
            num: 0
        };
    }

    componentDidMount() {
        store.subscribe(() => {
            console.log(store.getState());
            /*this.setState(store.getState(), function() {
                console.log(this.state.num);
            });*/
            this.setState(function() {
                return store.getState();
            }, function() {
                /*state更新完毕后执行回调*/
                console.log(this.state.num);
            });
        });
    }

    render() {
        return (
            <div>
                <p>{this.state.name}</p>
                <p>{this.state.num}</p>
                <input type="text" onChange={(event) => actions.changeName(event.target.value)} />
                <button onClick={event => actions.assess()}>access</button>
            </div>
        );
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值