首页 > 其他 > 详细

react redux

时间:2019-05-09 14:31:39      阅读:147      评论:0      收藏:0      [点我收藏+]

技术分享图片    

App.js
import React, { Component } from ‘react‘; import store from ‘./redux‘; import Com from "./com" class App extends Component { constructor(props){ super(props); console.log(store); console.log(store.getState());//获取数据 this.save = this.save.bind(this); this.state = { message: "", inputValue: "" }; store.subscribe(this.handleStoreChange);//监听store中的state改变 } render() { return ( <div className="App"> <input value = {this.inputValue} onChange={this.inputChange} /> <button onClick={this.save}>存储state</button> <p>{this.state.message}</p> <Com /> </div> ); } save(){ const action = { type: "msg",//必须有 value: this.state.inputValue } store.dispatch(action);//改变redux/reducer.js的state } handleStoreChange = () => { this.setState((preState) => { const newState = JSON.parse(JSON.stringify(preState)); const storeData = store.getState(); console.log(storeData) newState.message = storeData.message; return newState; }); } inputChange = (e) => { const value = e.target.value; this.setState((preState) => { const newState = JSON.parse(JSON.stringify(preState)); newState.inputValue = value; return newState; }); } } export default App;
redux/index.js
import { createStore } from ‘redux‘;
import reducer from ‘./reducer.js‘;

export default createStore(reducer); 
redux/reducer.js
export default (state = {}, action) => {
	console.log(state,action);
	const newState = JSON.parse(JSON.stringify(state));
	if(action.type == "msg"){
		newState.message = action.value;
		return newState;
	}
	
	if(action.type == "msg-msg"){
		newState.message = action.value;
		return newState;
	}
	
	return newState;
}

  

  

  

react redux

原文:https://www.cnblogs.com/whlBooK/p/10838096.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!