P11:Redux总结-三个React新手最容易犯的错误

AI 概述
Store必须是唯一的只有store能改变自己的内容,Reducer不能改变Reducer必须是纯函数 看到这里Redux基础部分也就快结束了,但是我有必要单独拿出一篇文章,把平时你容易犯的错误总结一下。本文的知识点你可能都已经知道,也可以省略不看。我总结了三个 React 新手最容易犯的错误。 store必须是唯一的,...
目录
文章目录隐藏
  1. Store必须是唯一的
  2. 只有store能改变自己的内容,Reducer不能改变
  3. Reducer必须是纯函数

看到这里Redux基础部分也就快结束了,但是我有必要单独拿出一篇文章,把平时你容易犯的错误总结一下。本文的知识点你可能都已经知道,也可以省略不看。我总结了三个 React 新手最容易犯的错误。

  • store必须是唯一的,多个store是坚决不允许,只能有一个store空间
  • 只有store能改变自己的内容,Reducer不能改变
  • Reducer必须是纯函数

Store必须是唯一的

现在看TodoList.js的代码,就可以看到,这里有一个/store/index.js文件,只在这个文件中用createStore()方法,声明了一个 store,之后整个应用都在使用这个store。 下面我给出了index.js内容,可以帮助你更好的回顾。

import { createStore } from 'redux'  //  引入 createStore 方法
import reducer from './reducer'    
const store = createStore(
    reducer,
    window.__REDUX_DEVTOOLS_EXTENSION__ && window.__REDUX_DEVTOOLS_EXTENSION__()) // 创建数据存储仓库
export default store   //暴露出去

只有store能改变自己的内容,Reducer不能改变

很多新手小伙伴会认为把业务逻辑写在了Reducer中,那改变 state 值的一定是Reducer,其实不然,在 Reducer 中我们只是作了一个返回,返回到了store中,并没有作任何改变。我这个在之前的笔记中也着重进行了说明。我们再来复习一下 Reducer 的代码,来加深印象。

Reudcer只是返回了更改的数据,但是并没有更改store中的数据,store拿到了Reducer的数据,自己对自己进行了更新。

import {CHANGE_INPUT,ADD_ITEM,DELETE_ITEM} from './actionTypes'

const defaultState = {
    inputValue : 'Write Something',
    list:[
        '早上 4 点起床,锻炼身体',
        '中午下班游泳一小时'
    ]
}
export default (state = defaultState,action)=>{
    if(action.type === CHANGE_INPUT){
        let newState = JSON.parse(JSON.stringify(state)) //深度拷贝 state
        newState.inputValue = action.value
        return newState
    }
    //state 值只能传递,不能使用
    if(action.type === ADD_ITEM ){ //根据 type 值,编写业务逻辑
        let newState = JSON.parse(JSON.stringify(state)) 
        newState.list.push(newState.inputValue)  //push 新的内容到列表中去
        newState.inputValue = ''
        return newState
    }
    if(action.type === DELETE_ITEM ){ //根据 type 值,编写业务逻辑
        let newState = JSON.parse(JSON.stringify(state)) 
        newState.list.splice(action.index,1)  //push 新的内容到列表中去
        return newState
    }
    return state
}

Reducer必须是纯函数

纯函数定义:

如果函数的调用参数相同,则永远返回相同的结果。它不依赖于程序执行期间函数外部任何状态或数据的变化,必须只依赖于其输入参数。

我们可以简单的理解为返回的结果是由传入的值决定的,而不是其它的东西决定的。比如下面这段Reducer代码。

export default (state = defaultState,action)=>{
    if(action.type === CHANGE_INPUT){
        let newState = JSON.parse(JSON.stringify(state)) //深度拷贝 state
        newState.inputValue = action.value
        return newState
    }
    //state 值只能传递,不能使用
    if(action.type === ADD_ITEM ){ //根据 type 值,编写业务逻辑
        let newState = JSON.parse(JSON.stringify(state)) 
        newState.list.push(newState.inputValue)  //push 新的内容到列表中去
        newState.inputValue = ''
        return newState
    }
    if(action.type === DELETE_ITEM ){ //根据 type 值,编写业务逻辑
        let newState = JSON.parse(JSON.stringify(state)) 
        newState.list.splice(action.index,1)  //push 新的内容到列表中去
        return newState
    }
    return state
}

它的返回结果,是完全由传入的参数stateaction决定的,这就是一个纯函数。

这个在实际工作中是如何犯错的?比如在Reducer里增加一个异步 ajax 函数,获取一些后端接口数据,然后再返回,这就是不允许的(包括你使用日期函数也是不允许的),因为违反了调用参数相同,返回相同的纯函数规则。

接下来我还会给大家继续讲解Redux的进阶部分,让大家对Redux的使用更加精通和深入。

以上关于P11:Redux总结-三个React新手最容易犯的错误的文章就介绍到这了,更多相关内容请搜索码云笔记以前的文章或继续浏览下面的相关文章,希望大家以后多多支持码云笔记。

「点点赞赏,手留余香」

0

给作者打赏,鼓励TA抓紧创作!

微信微信 支付宝支付宝

还没有人赞赏,快来当第一个赞赏的人吧!

声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 admin@mybj123.com 进行投诉反馈,一经查实,立即处理!
重要:如软件存在付费、会员、充值等,均属软件开发者或所属公司行为,与本站无关,网友需自行判断
码云笔记 » P11:Redux总结-三个React新手最容易犯的错误

发表回复