Web前端开发|Redux如何实现组合计数器?_惠州前端培训学校
作者:alu发布时间:2022-03-20分类:前端开发专业浏览:625
Redux如何实现组合计数器?这是大家在学习前端的过程都会遇到的问题,那么下面我们一起来看看惠州北大青鸟学术部老师是怎么解答的。
Redux实现组合计数器
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> <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: #64B587; border: 1px solid #F0BB40; input { flex: 1 1 auto; background-color: #64B587; 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); } } }
想了解更多关于前端的资讯,可以来惠州北大青鸟新方舟校区了解一下。
标签:惠州前端培训学校惠州前端基础惠州前端培训北大青鸟IT计算机学校北大青鸟IT软件学校前端北大青鸟IT学校惠州北大青鸟北大青鸟
- 前端开发专业排行
- 标签列表
-
- Java (3694)
- 北大青鸟 (3713)
- 软件开发 (3613)
- JAVA (3413)
- UI设计入门 (2093)
- 惠州北大青鸟 (4375)
- 惠州IT培训 (2558)
- UI设计培训 (2090)
- 惠州UI设计培训 (2095)
- 惠州UI设计培训学校 (2090)
- 惠州计算机软件培训 (6260)
- 惠州计算件软件开发 (6260)
- 惠州计算机软件基础 (6261)
- 惠州计算机JAVA培训 (3574)
- 惠州计算机Java软件开发 (3620)
- 惠州计算机JAVA软件开发 (4645)
- 惠州计算机JAVA软件开发学校 (3338)
- 惠州计算机Java软件开发培训 (3338)
- 北大青鸟IT计算机学校 (5048)
- 北大青鸟IT软件学校 (5062)
- 北大青鸟IT学校 (5059)
- 惠州计算机UI设计软件开发 (2088)
- UI设计基础教程 (2088)
- UI设计是什么 (2088)
- UI设计教程 (2088)
- 网站分类
-
- 计算机教程
- 计算机入门
- 职业学校
- 新闻动态
- 专业课程
- 热门技术
- SEO
- 培训教程
- windows
- linux教程
- 系统集成
- 网站开发
- Html5
- 办公软件
- 师资力量
- 热点问答
- 联系我们
- 计算机学校
- 惠州计算机学校
- 河源计算机学校
- 广州计算机学校
- 深圳计算机学校
- 湛江计算机学校
- 佛山计算机学校
- IT计算机培训信息
- 设计专业
- UI
- 影视特效
- 游戏动漫设计
- Photoshop
- AI设计
- 软件教程
- Java技术
- C语言/C++语言培训
- C#
- Python技术
- PHP
- 数据库
- SQL Server
- 网络教程
- 网络安全
- 网络营销
- 软件专业
- 大数据专业
- 前端开发专业
- 软件测试专业
- Python专业
- 软件实施
- 珠海计算机学校
- 初中生学什么好
- 计算机认证
- 文章归档
-
- 2024年11月 (14)
- 2024年10月 (32)
- 2024年9月 (29)
- 2024年8月 (68)
- 2024年7月 (59)
- 2024年6月 (43)
- 2024年5月 (48)
- 2024年4月 (80)
- 2024年3月 (65)
- 2024年2月 (54)
- 2024年1月 (25)
- 2023年12月 (12)
- 2023年11月 (73)
- 2023年10月 (134)
- 2023年9月 (34)
- 2023年8月 (3)
- 2023年7月 (3)
- 2023年6月 (12)
- 2023年5月 (30)
- 2023年4月 (72)
- 2023年3月 (11)
- 2023年2月 (34)
- 2023年1月 (37)
- 2022年12月 (78)
- 2022年11月 (359)
- 2022年6月 (1193)
- 2022年5月 (570)
- 2022年4月 (1567)
- 2022年3月 (982)
- 2022年2月 (54)
- 2022年1月 (182)
- 2021年9月 (308)
- 2021年8月 (1704)
- 2021年7月 (2423)
- 2021年6月 (1806)
- 2021年5月 (1569)
- 2021年4月 (1380)
- 2021年3月 (1255)
- 2021年2月 (709)
- 2021年1月 (1521)
- 2020年12月 (3626)
- 2020年11月 (1646)
- 2020年10月 (1046)
- 2020年9月 (592)
- 最近发表
-
- 清远信息:2024年广清杯清远南粤家政技能大赛举行决赛|||计算机培训机构
- 汕尾信息:陈良川带队到汕尾技师学院调研|||计算机职业技能培训班
- 东莞信息:凤岗凤岗镇组织召开社保参保缴费及劳动用工政策宣讲会|||计算机软件培训学校
- 阳江信息:2024年度注册城乡规划师职业资格考试的合格标准是怎样的?|||计算机软件培训学校
- 阳江信息:职业技能提升补贴对象有哪些?|||大学生计算机培训学校
- 清远信息:清远市首家社保服务合作网点在清城区举办启动仪式|||计算机职业技能培训班
- 汕头信息:招聘658名中高端人才!2024年汕头市引进中高端人才专场招聘会举行|||北大青鸟计算机培训中心
- 东莞信息:广东省社保智能经办现场会在东莞召开|||大学生计算机培训学校
- 东莞信息:东坑镇举办2024年重点群体系列招聘活动|||计算机职业技能培训班
- 东莞信息:万江万江街道成功举办第四届粤菜师傅烹饪技能竞赛|||广州计算机编程培训