当前位置: 首页 > wzjs >正文

wordpress的博客主题南京seo建站

wordpress的博客主题,南京seo建站,暗网网站,怎样做知道网站redux系列文章目录 第一章 简单学习redux,单个reducer 前言 前面我们学习到的是单reducer的使用;要知道redux是个很强大的状态存储库,可以支持多个reducer的使用。 combineReducers ‌combineReducers‌是Redux中的一个辅助函数,主要用于…

redux系列文章目录

第一章 简单学习redux,单个reducer

前言

前面我们学习到的是单reducer的使用;要知道redux是个很强大的状态存储库,可以支持多个reducer的使用。

combineReducers

‌combineReducers‌是Redux中的一个辅助函数,主要用于将多个子reducer合并成一个根reducer。这个函数接收一个对象,对象的键是子reducer的名称,值是子reducer函数。合并后的reducer可以调用各个子reducer,并将它们的结果合并成一个state对象。

代码

准备工作
基于上一章代码写新reducer,新增src/pages/users/index.js文件;新增src/redux/userReducer.js文件

store.js

import { createStore, combineReducers } from 'redux';
import counterReducer from './counterReducer'
import userReducer from './userReducer';//组合多个reducer,本章核心代码
const rootReducer = combineReducers({countNum: counterReducer,userList: userReducer
})let store = createStore(rootReducer);export default store

userReducer.js


function userReducer(state =[], action) {switch (action.type) {case 'ADDUSER':state.push(action.payload)return state;case 'DECUSER':// state.slice(0, -1)return state.slice(0, -1); ;default:return state;}
}   export default userReducer;

users/index.js

import React, { Fragment, useEffect, useState } from 'react'
import store from '../../redux/store'
export default function Users() {const [currenUsesName, setCurrenUsesName] = useState("")const [users, setUsers] = useState([])store.subscribe(() => {const { userList } = store.getState()setUsers((olduser)=>{return [...userList]})})return (<Fragment><div>输入新用户信息:<br /> 姓名: <input type="text" onChange={(e) => { setCurrenUsesName(e.target.value) }} />&nbsp;<button disabled={String(currenUsesName).trim().length === 0} onClick={() => {store.dispatch({ type: 'ADDUSER', payload: { name: currenUsesName, age: 18 } })}}>新增用户</button>&nbsp;<button disabled={users.length === 0} onClick={() => {store.dispatch({ type: 'DECUSER' })}}>减少用户</button><ul>{users?.map((item, index) => {return <li key={index}>姓名:{item.name} &nbsp; age:{item.age}</li>})}</ul></div></Fragment>)
}

最后,将写好的users/index.js引入couter组件中一起展示。可以得到下图效果

效果

多个reducer的效果

总结

上一章中,是单个reducer,这时候监听的store.getState(),是直接的state值。
本章中,是多个reducer,这时候监听的store.getState(),是object对象。

counterReducer

counterReducer(state = 0, action),counterReducer是第一个参数,是默认值;state可以是any类型,action是接收对象,默认接收是两个值{type:“”,payload};
payload可以传可不传

store.dispatch

dispatch()其也是接收对象,其对象也是{type:“”,payload};payload可以传可不传

http://www.dtcms.com/wzjs/498577.html

相关文章:

  • 培训机构倒闭seo必备软件
  • 企业网站公安备案吗深圳高端seo公司助力企业
  • 孝感 网站建设佛山网站搜索排名
  • 汽贸公司网站建设seo搜索优化工具
  • 十大旅游网站排名论坛推广案例
  • 建设规范文件在哪个网站发布中国百强城市榜单
  • 郑州网站制作公司汉狮深圳网络推广网站推广
  • 福建网站建设公百度提交入口网站网址
  • 蒲城做网站曼联目前积分榜
  • 建个商城网站需要多少钱湖北百度seo
  • 北理工网站开发与运用常州免费网站建站模板
  • 什么软件可以发布做网站如何在百度发布信息
  • 公司网站域名注册费用黄山网站seo
  • 网站建设人力资源分配google seo怎么做
  • 网站限时抢购怎么做seo蜘蛛屯
  • 苏州网站制作排名优化seo优化平台
  • 网站开发的方法有哪些seo是什么职位缩写
  • 帮别人做网站开什么内容的专票互联网营销师培训
  • 服装官网网站建设b2b电子商务网站
  • 广州知名网站建设网页设计服务网络营销薪酬公司
  • 河南网站建设公司首页关键词排名优化
  • 小网站建设公司线上商城的推广方案
  • 中国移动网络优化做什么的天津seo优化公司
  • 西安招聘网最新招聘搜索引擎营销优化的方法
  • 网站建设 开发 模板百度知道个人中心
  • 阜阳建设委员会网站关键词优化到首页怎么做到的
  • 网站建设工程结算方式百度一下首页
  • 建站网站企业网站建设目标
  • 优秀产品设计北京seo顾问推推蛙
  • 苏州网站建设培训学校幽默广告软文案例