你对 Redux 感到困惑吗?
如果使用新的 Redux Hooks,会更加简单!
这里是一个关于 Redux 的速成班,将配合 react 函数组件使用:
Redux 使您可以集中存放 JavaScript 应用程序的状态(数据)
它最常与 React 一起使用(通过 react-redux )
这使您可以从树中的任何组件访问或更改状态。
应用的状态被集中存放于 Redux store
该 store 是使用称为 “reducer” 的函数所创建的
reducer 接受一个 state 和一个 action ,
并返回相同或新的状态
使用 react-redux 中的 Provider 来为你的应用提供 store。
使用 Provider 来包装你的应用入口,以便应用程序中的任何组件都可以访问 store 中的数据
要从 store 中取出数据,请使用 react-redux 提供的自定义 hook :useSelector 。
selector 只是一个有趣的词:“从 store 获取数据的功能”
然后,向 useSelector 中传入回调,该回调中可获取整个 redux 的状态,您只需选择该组件所需的内容
action 是普通的 JavaScript 对象
所有 action 均应具有 “type” 键
它们可能还具有其他键(参数)
Actions 不是“调用”的,而是“分配”给 reducer 的
Action 的 type 属性告诉 reducer 接下来该做什么 (返回新状态或旧状态)
要更改 store 中的数据,请首先编写您的 reducer:
reducer 通常使用 switch / case 语句编写,但不是必要的
他们只需要得到一个动作和一个状态,然后返回一个新状态
重要的是,reducer 返回一个新的状态对象(而不是修改旧的对象的属性),这样,当对象中的属性发生某些改变时,组件将重新渲染。
不要在 reducer 中修改 state 中的值,仅返回一个值已经更改的拥有新状态的对象。
要分派 action ,请使用 react-redux 中的自定义 hook: useDispatch
用一个 action 对象来调用 useDispatch,
将传入 reducers 函数并运行,
有可能改变应用的状态
所有连接的组件(调用 useSelector )将自动获得新的状态
就像 props 或者 state 改变一样 - useSelector 将自动检测更改,React 将重新渲染组件。
Redux 可以以更复杂的方式使用,但核心始终是:
原文:Redux Crash Course with Hooks
作者:Chris Achard
译者:博轩
React项目实战:react-redux-router基本原理,Redux 的 React 绑定库包含了 容器组件和展示组件相分离 的开发思想。明智的做法是只在最顶层组件(如路由操作)里使用 Redux。其余内部组件仅仅是展示性的,所有数据都通过 props 传入。
flux四大元素:Dispatcher:根据注册派发动作(action),Store: 存储数据,处理数据,Action:用于驱动Dispatcher,View: 用户界面视图。flux的目的:纠正MVC框架的无法禁绝view与model通信的缺点。Redux基本原则:继承Flux基本原则:单向数据流
Redux:状态管理工具,与React没有任何关系,其他UI框架也可以使用Redux,react-redux:React插件,作用:方便在React项目中使用Redux,react-thunk:中间件,作用:支持异步action
compose,英文意思 组成,构成。它的作用也是通过一系列的骚操作,实现任意的、多种的、不同的功能模块的组合,用来加强组件。很容易实现功能的组合拼装、代码复用;可以根据需要组合不同的功能;
这里要讲的就是一个Redux在React中的应用问题,讲一讲Redux,react-redux,redux-thunk,redux-actions,redux-promise,redux-sage这些包的作用和他们解决的问题。
最近几天对 redux 的中间件进行了一番梳理,又看了 redux-saga 的文档,和 redux-thunk 和 redux-promise 的源码,结合前段时间看的redux的源码的一些思考,感觉对 redux 中间件的有了更加深刻的认识,因此总结一下
类似于 Vue,React 中组件之间的状态管理 第三方包为:react-redux。react-redux 其实是 Redux的官方React绑定库,它能够使你的React组件从Redux store中读取数据,并且向store分发actions以更新数据。
看到“reducer”这个词,容易让人联想到Redux,但是在本文中,不必先理解Redux才能阅读这篇文章。咱们将一起讨论“reducer”实际上是什么,以及如何利用useReducer来管理组件中的复杂状态,以及这个新钩子对Redux意味着什么?
我在读React-Redux源码的过程中,很自然的要去网上找一些参考文章,但发现这些文章基本都没有讲的很透彻,很多时候就是平铺直叙把API挨个讲一下,而且只讲某一行代码是做什么的,却没有结合应用场景和用法解释清楚为什么这么做。
我的许多同事最近通过各种方式问同一类问题:“如果我们开始用 hook 后,那还有必要用 Redux 吗?”“React hook 不是让 Redux 过时了吗?那只用 Hooks 就可以做 Redux 所有能做的事了吧?”
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!