码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Redux模式(reduck)


    学习Redux模式(reduck)

        • 1、定义
        • 2、优点:数据隔离,数据变化可溯源。
        • 3、缺点:多redux直接完全隔离,小型化困难,action方法容易膨胀。
        • 4、选择
        • 5、使用

    1、定义

    redux模式常规用法是作为整个应用全局状态管理使用。
    这只是作为一个提高跨组件通信的能力的工具。
    redux的思想是作为独立于组件的一个数据仓库,对数据进行保护,保障数据稳定可靠。

    简单理解redux就是一个带保护的全局使用的Context(useContext)。


    2、优点:数据隔离,数据变化可溯源。

    针对于原生的提供了数据保护(dispatch+reducer),对于更改只允许使用dispatch进行更改。能够保障可回溯性,数据来源清晰,能够十分良好的隔绝副作用。

    3、缺点:多redux直接完全隔离,小型化困难,action方法容易膨胀。

    对于大型项目拆分设计概念不足,store数据个人管控不友好,容易造成理解困难逻辑修改困难。

    4、选择

    如果组件之间的交流不多,逻辑不复杂,只是单纯的进行视图的渲染,这时候用回调,context就行,没必要用redux,用了反而影响开发速度。

    但是如果组件交流特别频繁,逻辑很复杂,那redux的优势就特别明显了。

    5、使用

    首先,在项目src文件夹下的model文件夹中创建一个存放全局变量的文件。这里可以创建多个,根据文件名字即可引用到相应的全局文件。

    然后在文件中可以直接使用react hooks的方法。这里以useState为例

    import { useState } from 'react';
    
    export default function globalFun() {
        const [count, setCount] = useState<number>(0);
        return {
            count,
            setCount
        };
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    最后在需要使用到全局变量的文件中引入即可。

    import { useModel } from 'umi';
    
    const {count, setCount} = useModel("xxx");  // xxx处填入创建model文件的名字
    
    console.log(count);
    
    return (
        <div onClick={()=>setCount(1)}></div>
    )
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
  • 相关阅读:
    新版收款码三合一在线生成系统源码
    [ESP32 Arduino] LVGL Button的使用
    1688API接口接入|阿里1688-B类电商基础链路专业化体验升级
    【前端开发】HTML1
    Entity Framework Core 基础 (1)
    神经网络时间序列分析,神经网络模型可解释性
    GCP谷歌云有什么数据库类型,该怎么选择
    Chapter006-FPGA学习之LCD显示
    【SQL】MySQL中的约束
    Windows 命令行cmd.exe简单介绍
  • 原文地址:https://blog.csdn.net/sinat_42338962/article/details/126347905
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号