最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Redux实现组合计数器的示例代码

来源:动视网 责编:小采 时间:2020-11-27 22:12:04
文档

Redux实现组合计数器的示例代码

Redux实现组合计数器的示例代码:Redux是一种解决数据共享的方案 import {createStore} from 'redux'; import React from 'react'; import ReactDOM from 'react-dom'; import {connect, createProvider} from 'react-redux' // dat
推荐度:
导读Redux实现组合计数器的示例代码:Redux是一种解决数据共享的方案 import {createStore} from 'redux'; import React from 'react'; import ReactDOM from 'react-dom'; import {connect, createProvider} from 'react-redux' // dat


Redux是一种解决数据共享的方案

import {createStore} from 'redux';
import React from 'react';
import ReactDOM from 'react-dom';
import {connect, createProvider} from 'react-redux'


// data
let allNum = {num :1000}

// 创建reducer, 名字的默认值为
function reducer(state, action) {
 let tmp = {}
 if (action.type == "decrease"){
 allNum.num = allNum.num - action.value;
 tmp = Object.assign({}, state, {num: allNum.num})
 return tmp
 }else if(action.type == "increase"){
 allNum.num = allNum.num + action.value;
 tmp = Object.assign({}, state, {num: allNum.num})
 return tmp
 }else{
 return state
 }
}

// 创建store存储数据(传入处理函数reducer, 核心数据allNum)
let store = createStore(reducer, allNum)
console.log("初始化的数据为",store.getState('num'))

// 添加监听函数
store.subscribe(() => {console.log("监听函数发出:", store.getState())});

// 发出action
let tmp = {};
tmp = store.dispatch({type: "decrease", value: 10})
console.log("---->", tmp);
tmp = store.dispatch({type: "decrease", value: 100})
console.log("---->", tmp);
tmp = store.dispatch({type: "increase", value: 31})
console.log("---->", tmp);
tmp = store.dispatch({type: "increase", value: 123})
console.log("---->", tmp);

class MyComponent extends React.Component {
 render() {return <div>Hello World</div>;}
}

ReactDOM.render(<MyComponent />, document.getElementById("root"));

React和Redux组合使用

React组件, 有两个数据集, props和state

props表示外部传入组件的参数(数据由外部传入, 可以被外部更改)

state表示组件固有的属性(数据私有, 不可以被外部更改)

我们可以把多个React组件的props交由Redux进行管理, 这样就实现了React组件之间数据的共享

组件如何读写数据

组件通过action发送信号, reducer处理action, story内的值被reducer修改, 由于React组件已经被绑定到story中, 所以story内的数据被修改后, 可以直接同步到React的组件中

小案例: 实现一个组合计数器

单个计数器的数据由组件自身state管理

三个计数器的数据只和由Redux管理

动图演示

实现的源码如下

index.html

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>react-webpack-demo</title>
</head>
<body>
 <div id="root"></div>
</body>
</html>

index.js

import 'babel-polyfill';
import React from 'react';
import ReactDOM from 'react-dom';
import './index.scss';
import Redux from 'redux';
import { connect, Provider } from 'react-redux';
import { createStore } from 'redux';
import { PropTypes } from 'prop-types';

class ManageCounter extends React.Component {
 constructor(props) {
 super(props);
 }

 render() {
 return ( <div>
 <p className="title">计数器</p> 
 <Counter id = "0" />
 <Counter id = "1" />
 <Counter id = "2" />
 <p className="result"> 组件值的和为: { this.props.sum } </p> 
 </div> )
 }
}


class Counter extends React.Component {
 constructor(props) {
 super(props);
 this.changeSum = this.changeSum.bind(this)
 this.decrease = this.decrease.bind(this)
 this.increase = this.increase.bind(this)
 this.state = { value: 0 };
 }
 changeSum() {
 this.props.dispatch({ type: 'changeSum', payload: { id: this.props.id, value: this.state.value } })
 }
 decrease() {
 let self = this;
 this.setState({ value: this.state.value - 1 }, () => {
 self.changeSum()

 })
 }

 increase() {
 let self = this;
 self.setState({ value: this.state.value + 1 }, () => {
 self.changeSum()
 })
 }

 render() {
 const { value } = this.state;
 let { id } = this.props;
 return ( <div >
 <input type = "button"value = "减1" onClick = { this.decrease }/> 
 <span > { value } < /span><br/ >
 <input type = "button" value = "加1" onClick = { this.increase }/>
 </div> )
 }
}

// 创建reducer
function reducer(state = { number: [0, 0, 0], sum: 0 }, action = {}) {
 if (action.type == 'changeSum') {
 let { id, value } = action.payload
 console.log("id:", id, "value:", value);
 state.number[id] = value
 let tmpSum = 0;
 for (let i = 0; i < state.number.length; i++) {
 tmpSum += state.number[i]
 }
 return Object.assign({}, state, { sum: tmpSum });
 } else {
 return state;
 }
}

const CounterMapStateToProps = (state) => ({

})

const ManageCounterMapStateToProps = (state) => ({
 sum: state.sum
})

const mapDispatchToProps = (dispatch) => ({
 dispatch: dispatch
})


// 创建store
let store = createStore(reducer)
// connect连接
Counter = connect(CounterMapStateToProps, mapDispatchToProps)(Counter)
ManageCounter = connect(ManageCounterMapStateToProps, mapDispatchToProps)(ManageCounter)

ReactDOM.render(
 <Provider store = { store }>
 <ManageCounter />
 </Provider> ,
 document.getElementById('root'));

index.scss

$designWidth: 750;
@function px2rem($px) {
 @return $px*10/$designWidth+rem;
}

#root {
 div {
 p {
 font-size: px2rem(300);
 color: #5EA1F3;
 text-align: center;
 }
 div {
 font-size: px2rem(500);
 display: flex;
 color: #B587;
 border: 1px solid #F0BB40;
 input {
 flex: 1 1 auto;
 background-color: #B587;
 font-size: px2rem(200);
 outline: none;
 color:#ffffff;
 }
 span {
 width: 300px;
 flex: 1 1 auto;
 text-align: center;
 }
 }
 .title {
 color: #BDBDBD;
 }
 .result {

 font-size: px2rem(200);
 }
 }
}

小结

redux的设计思想是很简单的, 也有了很成熟的库函数供我们调用, 所以面对一个问题时, 我们考虑的重点是: React组件内哪些数据需要被Redux管理?把重点问题考虑清楚, 问题也就解决了大半!

文档

Redux实现组合计数器的示例代码

Redux实现组合计数器的示例代码:Redux是一种解决数据共享的方案 import {createStore} from 'redux'; import React from 'react'; import ReactDOM from 'react-dom'; import {connect, createProvider} from 'react-redux' // dat
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top