React全家桶及原理解析-lesson4-Redux

lesson4-react全家桶及原理解析.mov

React全家桶及原理解析

  • React全家桶及原理解析
    • 课堂⽬标
    • 资源
    • 起步
    • Reducer
      • 什么是reducer
      • 什么是reduce
    • Redux 上⼿
      • 安装redux
      • redux上⼿
      • 检查点
    • react-redux
      • 异步
      • 代码抽取
    • Redux拓展
      • redux原理
        • 核⼼实现
        • 中间件实现
      • redux-thunk原理
      • react-redux原理
        • 实现kreact-redux
        • 实现bindActionCreators
  • 作业

课堂⽬标

  1. 掌握redux
  2. 掌握redux中间件
  3. 实现redux、react-redux及其中间件原理

资源

  1. redux
  2. react-redux

起步

Reducer

什么是reducer

reducer 就是⼀个纯函数,接收旧的 state 和 action,返回新的 state。

;(previousState, action) => newState

之所以将这样的函数称之为 reducer,是因为这种函数与被传⼊
Array.prototype.reduce(reducer, ?initialValue) ⾥的回调函数属
于相同的类型。保持 reducer 纯净⾮常重要。永远不要在 reducer ⾥做这些操作:

  • 修改传⼊参数;
  • 执⾏有副作⽤的操作,如 API 请求和路由跳转;
  • 调⽤⾮纯函数,如 Date.now() 或 Math.random()。

什么是reduce

此例来⾃https://developer.mozilla.org/en-US/docs/Web/JavaScript/Ref
erence/Global_Objects/Array/Reduce

const array1 = [1, 2, 3, 4];
const reducer = (accumulator, currentValue) => accumulator + currentValue;
// 1 + 2 + 3 + 4
console.log(array1.reduce(reducer));
// expected output: 10
// 5 + 1 + 2 + 3 + 4
console.log(array1.reduce(reducer, 5));
// expected output: 15

思考:有如下函数, 想要顺序输出1 2 3,如何处理。

function f1() {console.log("f1");
}
function f2() {console.log("f2");
}
function f3() {console.log("f3");
}

⽅法1:

f1();f2();f3();

⽅法2:

f3(f2(f1()));

⽅法3:

function compose(...funcs) {if (funcs.length === 0) {console.log("empty");} else if (funcs.length === 1) {return funcs[0];} else {return funcs.reduce((left, right) => (...args) => right(left(...args)));}
}
compose(f1,f2,f3,
)();

Redux 上⼿

Redux是JavaScript应⽤的状态容器。它保证程序⾏为⼀致性且易于测试。

安装redux

npm install redux --save

redux上⼿

redux较难上⼿,是因为上来就有太多的概念需要学习 ,⽤⼀个累加器举例

  1. 需要⼀个store来存储数据
  2. store⾥的reducer初始化state并定义state修改规则
  3. 通过dispatch⼀个action来提交对数据的修改
  4. action提交到reducer函数⾥,根据传⼊的action的type,返回新的state

创建store,src/store/ReduxStore.js

import {createStore} from 'redux'
const counterReducer = (state = 0, action) => {switch (action.type) {case 'add':return state + 1case 'minus':return state - 1default:return state}}
const store = createStore(counterReducer)
export default store

创建ReduxPage

import React, { Component } from "react";
import store from "../store/ReduxStore";
export default class ReduxPage extends Component {componentDidMount() {store.subscribe(() => {console.log("subscribe");this.forceUpdate();//this.setState({});});}add = () => {store.dispatch({ type: "add" });};minus = () => {store.dispatch({ type: "minus" });};stayStatic = () => {store.dispatch({ type: "others" });};render() {console.log("store", store);return (<div><h1>ReduxPage</h1><p>{store.getState()}</p><button onClick={this.add}>add</button><button onClick={this.minus}>minus</button><button onClick={this.stayStatic}>static</button></div>);}
}

如果点击按钮不能更新,因为没有订阅状态变更

还可以在src/index.js的render⾥订阅状态变更

import store from './store/ReduxStore'
const render = () => {ReactDom.render(<App/>,document.querySelector('#root'))
}
render()
store.subscribe(render

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

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

相关文章

AI和信号处理推荐书单

推荐AI书单 1、《动手学深度学习-pytorch版》 https://item.m.jd.com/product/10068173196371.html?utm_sourceiosapp&utm_mediumappshare&utm_campaignt_335139774&utm_termCopyURL&ad_odshare&gxRnAomTM2bWfQmswcp40mDrUkxA7sLkk&gxdRnAoymFZOTXe…

【数据可视化】Echarts官方文档及常用组件

个人主页 &#xff1a; zxctscl 如有转载请先通知 文章目录 1. 前言2. Echarts官方文档介绍3. ECharts基础架构及常用术语3.1 ECharts的基础架构3.2 ECharts的常用术语3.2.1 ECharts的基本名词3.2.2 ECharts的图表名词 4. 直角坐标系下的网格及坐标轴4.1 直角坐标系下的网格4.2…

关于BFF

BFF&#xff08;Backend For Frontend&#xff09;是一种架构设计模式&#xff0c;用于解决多端&#xff08;如Web、移动端等&#xff09;共用一个后端服务时的问题。BFF的主要目标是将前端与后端的业务逻辑分离&#xff0c;使得前端可以根据自身的需求定制接口和数据&#xff…

C++的语法

可能需要用到存储各种数据类型&#xff08;比如字符型、宽字符型、整型、浮点型、双浮点型、布尔型等&#xff09; 下表显示了各种变量类型在内存中存储值时需要占用的内存&#xff0c;以及该类型的变量所能存储的最大值和最小值。 注意&#xff1a;不同系统会有所差异 #inc…

CentOS7 操作firewall防火墙

常用命令 开启关闭防火墙 systemctl start/status/stop/disable firewalld查看默认区域名称 $ firewall-cmd --get-default-zone public查看区域信息 firewall-cmd --get-active-zones查看指定接口所属区域 firewall-cmd --get-zone-of-interfaceeth0查看防火墙配置 # 查…

Qt Excel文件读写

QAxObject是Qt框架中用于与ActiveX控件和COM对象进行交互的类。它使得在Qt应用程序中嵌入和使用ActiveX控件&#xff0c;或者操作COM对象成为可能。通过QAxObject&#xff0c;你可以在Qt中方便地操作Excel、Word等Office应用程序&#xff0c;以及许多其他支持ActiveX或COM技术的…

AI人工智能小程序系统开发

开发AI人工智能小程序系统需要以下步骤&#xff1a; 1. 确定需求&#xff1a;了解客户对人工智能小程序的期望&#xff0c;并分析系统的实际应用场景。 2. 设计架构&#xff1a;选择合适的技术框架和人工智能算法&#xff0c;进行小程序系统架构的设计。 3. 数据采集和处理&…

诺视科技完成亿元Pre-A2轮融资,加速Micro-LED微显示芯片商业化落地

近日&#xff0c;Micro-LED微显示芯片研发商诺视科技&#xff08;苏州&#xff09;有限公司&#xff08;以下简称“诺视科技”&#xff09;宣布完成亿元Pre-A2轮融资&#xff0c;本轮融资由力合资本领投&#xff0c;老股东盛景嘉成、汕韩基金以及九合创投持续加码&#xff0c;这…

【漏洞复现】北京新网医讯技术有限公司云端客服管理系统存在SQL注入漏洞

免责声明&#xff1a;文章来源互联网收集整理&#xff0c;请勿利用文章内的相关技术从事非法测试&#xff0c;由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;所产生的一切不良后果与文章作者无关。该…

【Linux】cat vim 命令存在着什么区别?

Linux 中的 cat 命令和 vim 命令之间存在一些显著的区别&#xff01; cat 命令 首先&#xff0c;cat命令主要用于连接并显示文件的内容。它的原含义是“连接&#xff08;concatenate&#xff09;”&#xff0c;可以将多个文件的内容连接起来&#xff0c;并输出到标准输出流中&…

python模块

模块导入方式 模块需要在使用前进行导入 语法&#xff1a;[from 模块名] import [ 模块 | 类 | 函数 | *] [ as 别名 ] * 代表全部将该模块全部导入 from 模块名 import 功能名 #导入时间模块中的sleep方法 from time import sleep 注意&#xff1a;from可以省略 直接…

python使用appium在指定的坐标位置点击

在Appium中&#xff0c;要在指定的坐标位置执行点击操作&#xff0c;你可以使用TouchAction类配合press和release方法。下面是一个简单的示例代码&#xff0c;展示了如何在指定的(x, y)坐标位置执行点击操作&#xff1a; from appium import webdriver from appium.webdriver.…

掘根宝典之C++正向迭代器和反向迭代器详解

简介 迭代器是一种用于遍历容器元素的对象。它提供了一种统一的访问方式&#xff0c;使程序员可以对容器中的元素进行逐个访问和操作&#xff0c;而不需要了解容器的内部实现细节。 C标准库里每个容器都定义了迭代器&#xff0c;这迭代器的名字就叫容器迭代器 迭代器的作用类…

java Flink(四十二)Flink的序列化以及TypeInformation介绍(源码分析)

Flink的TypeInformation以及序列化 TypeInformation主要作用是为了在 Flink系统内有效地对数据结构类型进行管理&#xff0c;能够在分布式计算过程中对数据的类型进行管理和推断。同时基于对数据的类型信息管理&#xff0c;Flink内部对数据存储也进行了相应的性能优化。 Flin…

php中 Serializable 接口详解

Serializable 是 PHP 中一个内置的接口&#xff0c;它为对象提供了自定义的序列化和反序列化能力。实现这个接口的类可以控制它们的序列化行为&#xff0c;即它们如何被序列化到字符串以及如何从字符串反序列化回对象。 当一个对象需要被存储或在网络间传输时&#xff0c;通常…

深入理解 C# Unity 中的事件和委托

事件和委托是 C# Unity 游戏开发中的基本概念,可实现游戏不同部分之间的通信和交互。在本文中,我们将以简单的术语探讨这些概念,以帮助Unity 项目中利用它们发挥应有的作用 目录 事件和委托: 1. 什么是 C# 事件? 2、声明: 3. 订阅活动: 4. 发布活动: 5.

C++ 11

目录 1. 统一的列表初始化 1.1 &#xff5b;&#xff5d;初始化 1.2 std::initializer_list 2. decltype 3. 右值引用和移动语义 3.1 左值引用和右值引用 3.2 左值引用与右值引用比较 3.3 右值引用使用场景和意义 3.4 右值引用引用左值及其一些更深入的使用场景分析 3…

[论文笔记] Gradient Surgery for Multi-Task Learning

【强化学习 137】PCGrad - 知乎 多任务学习(multi task):任务权重、loss均衡、梯度下降那点事 - 知乎 ICLR 2020 rejected submission:Yu T, Kumar S, Gupta A, et al. Gradient surgery for multi-task learning[J]. arXiv preprint arXiv:2001.06782, 2020. mul…

p2p原理

p2p原理 P2P (Peer-to-Peer) 是一种分布式计算和网络架构模型&#xff0c;它允许对等节点之间直接通信和共享资源&#xff0c;而无需通过集中的服务器。P2P 原理的核心概念是平等性&#xff08;peer equality&#xff09;&#xff0c;即所有节点在网络中都具有相同的功能和能力…

动态规划 Leetcode 139 单词拆分

单词拆分 Leetcode 139 学习记录自代码随想录 要点在注释中详细说明&#xff0c;注意迭代公式中是dp[i]不是dp[j-i] #include <stdio.h> #include <string.h> #include <stdbool.h> #include <stdlib.h>bool wordBreak(char* s, char** wordDict, …