redux

Posted panghexin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了redux相关的知识,希望对你有一定的参考价值。

显示react脚手架的配置文件使用指令:npm run eject,如果出现报错,我们需要使用git将工作区的文件放到本地库上,指令:git add .

将工作区的文件添加到暂存区git commit -m ‘first commit‘,将暂存区提交到本地库npm run eject,此时我们的配置文件就出来了

如果我们想使用 css 的预编译语言:scss,我们需要下载 sass-loader node-sass 模块,无需配置文件,将 css 文件改成 scss 文件就可以了;

  指令:npm i sass-loader node-sass -D

  redux 是 js 的状态管理机,适用于 vue,react,angular,在 react 的使用率更高;

  redux 的下载指令:npm i redux -S

  三大原则:单一数据源,state 是只读的,改变他使用 action

  案例:

    技术图片

  redux 的核心

    1. store 保存数据的地方,这些数据叫 state ,必须通过 store.getState() 来获取 state

    2. reducer 是 createStore() 的第一个参数,是一个函数,主要是用来生成新的 state,主要接收两个状态,一个是 state,一个是 action,返回新的状态

    3. action 是一个对象,所有 state 的改变都是用户通过视图层 view,提交到 action,action 是改变 state 的唯一途径

  action 是一个对象

  action =

    type: ‘add‘,  // 事件类型

    payload: 1  // 载荷,伴随函数传过来的参数

  

  store.dispatch() 是 view 层唯一发出 action 的方法,参数是一个 action 对象

  index.js 

  监听页面的方法

  store 是 createState() 的返回值

  store.subscribe(),当 state 里面的数据发生了变换,就会调用这个函数,且这个函数有个返回值,调用这个返回值,就会停止监听里面的事件

  案例:在 index.js 中

    技术图片

 

  redux 的使用方法,

  技术图片

 

  为什么使用 action.js 文件,进行优化代码将其分开,然后我们通过工厂函数的每次返回不同的对象,由于参数是固定的,每次返回的都是事件类型和事件数据,所以我们可以使用一个函数,通过其返回值来返回一个对象,让后传递给 action ;

  我们的 reducer 函数有两个参数,参数一:state,参数二:action,

  我们的 redux 中有一个 createStore() 的函数,参数是 reducer 函数,并且有一个返回值,就是 store,管理 redux 的 state 的数据;

  如果我们向渲染到页面上,我们就需要借助 store.subscribe() 的函数,监听 state,每次页面刷新都会调用此函数,虽然每次更给都会调用此方法,但因为是 diff 算法,所以并不会影响性能;

  所以,核心 store.js 处理逻辑,index.js 来渲染页面,组件来提交事件

 

以上是关于redux的主要内容,如果未能解决你的问题,请参考以下文章

react全家桶从0搭建一个完整的react项目(react-router4reduxredux-saga)

react状态管理器

Redux 知识点 及 使用案例

Redux原理探索

React

React