22-Redux-1

news2025/2/27 17:21:14

 


//npm init
//npm install redux
//1 导入redux(不能通过es6的方式)
// commonjs一种 -> node.js

const redux = require('redux')

const initialState = {
  counter: 0
}
// reducer
function reducer(state = initialState, action) {
  switch(action.type) {
    case "INCREMENT":
      return { ...state, counter: state.counter + 1 }
    case "DECREMENT":
      return { ...state, counter: state.counter - 1 }
    case "ADD_NUMBER":
      return { ...state, counter: state.counter + action.num }
    case "SUB_NUMBER":
      return { ...state, counter: state.counter - action.num }
    default:
      return state
  }
}

//store
const store = redux.createStore(reducer)

//订阅store的修改
store.subscribe(() => {
  console.log("state发生了改变", "counter:", store.getState().counter)
})

//actions
const action1 = { type: "INCREMENT" }
const action2 = { type: "DECREMENT" }
const action3 = { type: "ADD_NUMBER", num: 5 }
const action4 = { type: "SUB_NUMBER", num: 12 }

//派发 action
store.dispatch(action1)
store.dispatch(action2)
store.dispatch(action3)
store.dispatch(action4)

升级版本脱离react直接使用

 index.js

import store from './store/index.js'
import { addAction, subAction, inAction, deAction } from './store/actionCreators.js'

store.subscribe(() => {
  console.log(store.getState())
})


store.dispatch(addAction(10))
store.dispatch(subAction(5))

store.dispatch(inAction())
store.dispatch(deAction())

store文件夹

actionCreator.js

 


import {  ADD_NUMBER, SUB_NUMBER, INCREMENT, DECREMENT   } from './constants.js'

export const addAction = (num) => {
  return {
    type: ADD_NUMBER,
    num,
  }
}
export const subAction = (num) => {
  return {
    type: SUB_NUMBER,
    num,
  }
}

export const inAction = () => {
  return {
    type: INCREMENT,
  }
}

export const deAction = () => {
  return {
    type: DECREMENT,
  }
}

constants.js

export const ADD_NUMBER = "ADD_NUMBER";
export const SUB_NUMBER = "SUB_NUMBER";
export const INCREMENT = "INCREMENT";
export const DECREMENT = "DECREMENT";

index.js



import redux from 'redux'

import reducer from './reducer.js'

const store = redux.createStore(reducer)

export default store

reducer.js

 

import {  ADD_NUMBER, SUB_NUMBER, INCREMENT, DECREMENT   } from './constants.js'

const defaultState = {
  counter: 0
}

function reducer(state = defaultState, action) {
  switch(action.type) {
    case ADD_NUMBER:
      return { ...state, counter: state.counter + action.num }
    case SUB_NUMBER:
      return { ...state, counter: state.counter - action.num }
    case INCREMENT:
      return { ...state, counter: state.counter + 1 }
    case DECREMENT:
      return { ...state, counter: state.counter - 1 }
    default:
      return state
  }
}

export default reducer

 在react中引用index.js

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/9651.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

5 步!用阿里云 Serverless 搭建高质量的图片压缩工具

作者:Regan Yue 本文选自“Serverless 函数计算征集令”活动 什么是 Serverless Serverless 是一种基于云计算的开发方法,它让开发人员可以专注于编写代码来解决业务问题,而不是处理服务器问题。它是独一无二的,因为它支持 Auto …

Rust中级教程:指针生态(引用、原始指针、智能指针)and内存操作(Stack、Heap)

指针的一些概览知识点 1.内存地址:指代内存中单个字节的一个整数。 指针(原始指针):就是指向某种类型的一个内存地址。 引用:就是指针,是rust提供的一种抽象,如果是动态大小,就是一…

标记肽MGP-7-氨基-4-甲基香豆素、1926163-53-2、Met-Gly-Pro-AMC

蛋氨酸氨基肽酶1D和2的荧光底物。编号: 152397 中文名称: 标记肽MGP-7-氨基-4-甲基香豆素 英文名: H-Met-Gly-Pro-AMC CAS号: 1926163-53-2 单字母: H2N-MGP-AMC 三字母: H2N-Met-Gly-Pro-AMC 氨基酸个数: 3 分子式: C22H28N4O5S1 平均分子量: 460.55 精确分子量: 460.18 等电点…

【SVN】SVN服务端地址变动,idea切换SVN地址

公司切换了SVN服务端的制度,需要本地对应切换SVN地址,以下为具体步骤 错误方式 直接 项目上右键 --> Subversion --> Relocate ,修改 To URL 的值,会报错 https://XXXXX is not the root of the repository 的错误 正确的…

Communication-Efficient Learning of Deep Networks from Decentralized Data

international conference on artificial intelligence and statistics Summary 当前机器学习模型训练中存在着数据隐私保护问题,所以作者提出了FL概念。通过分布式隐私保护进行训练模型。对不平衡、non-IID的数据也更合适。 主要提出了FedSGD和FedAvg算法。FedAv…

Andriod开发R文件爆红相关解决方法及排查方案

1.首先尝试下基本的处理方法: 在IDE中工具栏处选择build 尝试clean project,然后再进行rebuild project或者是make project 若使用的是IDEA或Android studio,在上述方法尝试后可以尝试工具栏中File->Setting->Invalidate Caches/Rest…

微信小程序(基础语法)

文章目录基本组件视图容器viewscroll-viewswiper和swiper-item基础内容组件textrich-text其他常用组件buttonimagenavigator基本模板数据绑定插值表达式事件绑定常用事件在事件处理函数中为data的数据赋值事件传参bindinput的使用小程序中的v-model条件渲染wx:ifhidden列表渲染…

一些关于通信拓扑、图论的内容笔记

链接:https://zhuanlan.zhihu.com/p/373368383 目前主要是这一个系列,记下来怕我过后忘了。 别处看到的(大概率3B1B)----走桥的问题----d偶数 多智能体一致性问题(分蛋糕) 入度 出度 :信息流…

007_补充_ Pytorch 反向传播和Neural ODE的反向传播

一、Pytorch反向传播 首先是第一个小例子,训练模型拟合 y true_w * x true_b,模型的参数为 param_w, param_b import torchtrue_w torch.Tensor([[2.0, 3.0], [4.0, 5.0]]) # 初始化真实的参数 true_b torch.Tensor([[1.0, 2.0], [3.0, 4.0]]) #…

linux安装jdk17

登录linux 我使用的是Alibaba Cloud Linux 3.2104 LTS 64位操作系统,登录后结果如下: Welcome to Alibaba Cloud Elastic Compute Service !Updates Information Summary: available7 Security notice(s)5 Important Security notice(s)2 Moderate Sec…

2023最新SSM计算机毕业设计选题大全(附源码+LW)之java校园二手商品交易系统p11v7

毕业设计说实话没有想象当中的那么难,导师也不会说刻意就让你毕设不通过,不让你毕业啥的,你只要不是太过于离谱的,都能通过的。首先你得要对你在大学期间所学到的哪方面比较熟悉,语言比如JAVA、PHP等这些,数…

laravel对于数据量特别大的导出excel的提速方案

背景:一些业务场景需要导出excel的需求,但是面对日益增长的数据,要导出的数据会越来越大。生成表格的时间也会越来越慢。针对这个问题,目前的业务通过两个角度去提速。 1:异步导出 如果数据量达到一定的体量&#xf…

【毕业设计】大数据大众点评评论文本分析 - python 数据挖掘

文章目录0 前言1 爬虫1.1 整体思路1.2 网页爬取和解析1.3 数据存储1.4 反爬虫对抗2 探索性分析与文本数据预处理2.1 探索性分析2.2 数据预处理2.3 词云展示3 文本的情感分析3.1 先上结果3.2 文本特征提取(TF-IDF)3.3 机器学习建模3.4 最后输出的准确率4 …

java ssh校园拼餐系统

首先在系统前台,游客用户可以经过账号注册,管理员审核通过后,用账号密码登录系统前台,查看拼餐服务、网站公告、文明拼餐员、会员风彩、系统简介、咨询信息、拼餐信息等栏目信息,进行在线咨询和管理员交流,…

LTSPICE使用教程:二极管钳位电路仿真

在我们查看芯片内部的设计电路时,通常会发现以下的电路结构: 当定义pin脚输入电压Vpin, 1.Vpin>VDD,二极管D1导通,D2截止,此时无论怎样继续加大VPIN的输入电压时, 进入到管脚内部的电压会被钳制在Vint…

【RocketMQ中生产者生产消息的高可用机制、消费者消费消息的高可用机制、消息的重试机制、死信队列于死信消息】

一.知识回顾 【0.RocketMQ专栏的内容在这里哟,帮你整理好了,更多内容持续更新中】 【1.Docker安装部署RocketMQ消息中间件详细教程】 【2.RocketMQ生产者发送消息的三种方式:发送同步消息、异步消息、单向消息&案例实战&详细学习流程】 【3.Rock…

野火FPGA入门(5)

文章目录第17讲:触摸按键控制LED灯第18讲:流水灯第19讲:呼吸灯第20讲:状态机第21讲:无源蜂鸣器驱动实验第17讲:触摸按键控制LED灯 触摸按键可分为四大类:电阻式、电容式、红外感应式、表面声波…

调优工具常用命令

语法格式 mysqldumpslow [ OPTS... ] [ LOGS... ] //命令行格式常用到的格式组合 -s 表示按照何种方式排序c 访问次数l 锁定时间r 返回记录t 查询时间al 平均锁定时间ar 平均返回记录数at 平均查询时间 -t 返回前面多少条数据 -g 后边搭配一个正则匹配模式,大小写…

机械专业学子的芯片封装仿真“逆袭之路”

作者:萧显军 导读:近期,ANSYS公司给清华大学集成电路学院捐赠了一批业界领先的计算机辅助工程(CAE)软件及自动化(EDA)软件,为清华大学的芯片设计仿真的教学科研工作提供更强大的软件服务与技术支撑。 捐的仿真软件包括ANSYS涉及…

小白学Java

ip地址:用于唯一识别标记网络中的每一台计算机 查看方法:ipconfig ip地址的表示形式:点分十进制 xx.xx.xx.xx 每个十进制数的范围:0-255 ip地址的组成 网络地址主机地址 ipv4地址分类: (特殊:…