美文网首页
Redux基础

Redux基础

作者: 冫改网名 | 来源:发表于2019-03-30 16:15 被阅读0次

Redux的产生

要理解redux的产生,先要说说MVC模式。每一个view(页面)对应一个model,并由对应的control控制。页面离不开数据的支持,随着单页应用的普及,技术实现的复杂性,页面的状态state管理(用户输入的数据、标签的选中状态、)日趋复杂。

管理不断变化的 state 非常困难。如果一个 model 的变化会引起另一个 model 变化,那么当 view 变化时,就可能引起对应 model 以及另一个 model 的变化,依次地,可能会引起另一个 view 的变化。直至你搞不清楚到底发生了什么。state 在什么时候,由于什么原因,如何变化已然不受控制。
Redux的产生则是为了方便开发者管理state,并保持应用的历史状态(返回功能),实现应用状态的可预测。

Redux的原则

  • 单一数据源,即唯一store。store中存在包含整个应用state的object tree
  • state只读,Redux中不能直接修改state,必须通过action来触发修改
  • 使用纯函数来修改state,reducer必须是纯函数

Redux基础概念

state:页面中的状态,类似一个Object
Action:单纯的JavaScript队形,用于更改state中的值
reducer:连接state和Action的函数

Redux的使用方法

页面state:

this.state = { name: 'bamboo', text:'耐得住寂寞才能守得住繁华' }

action:

{
  type: Change,
  text: 'change the text'
}

reducer:接收一个state和一个action,返回新的state

function Change(state, action) {
  if (action.type === 'Chanage') {
    return { name: 'bamboo', text: '偷懒一时爽,一直偷懒一直爽' };
  } else return state;
  // 遇到未知action时,返回原有的state
}

页面中有一个按钮onClick事件触发Change这个action,改变该页面的state,重新渲染页面,页面内容text变化。

相关文章

  • 1-Redux Introduction

    Time: 20200129 前置要求 React基础 Redux Redux is a predictable ...

  • 07-05-Redux

    课程目标 掌握 redux 三大原则; 掌握 redux 基础使用; 掌握 react-redux 使用; 掌握 ...

  • 轻松搞定 -react-redux-基本用法

    1. 前言 之前写了几篇关于 redux和react-redux文章,链接如下redux-基础[https://w...

  • spring-boot redux-thunk增删改查

    环境搭建 以spring-boot react redux增删改查为基础代码,在redux分支的基础上,集成red...

  • 【学习笔记 】React ⑥ Redux工作流

    Redux基础概念     在了解Redux之前首先思考一个问题:为什么要使用Redux?    React是一个...

  • react 学习

    包含 react基础 react传值 react路由 和redux管理 和react-redux reactDom...

  • 【React进阶系列】手写实现react-redux api

    简介:简单实现react-redux基础api react-redux api回顾 把store放在context...

  • redux学习(中)

    依照惯例,开头先放出redux中文文档地址 前文讲了redux的基础概念,这次学习一下redux和react的结合...

  • redux基础

    初始化 1、通过reducer创建store,store=create(reducer,initValues)将s...

  • Redux基础

    Actions Actions是用于存放数据的载体,通过store.dispatch()函数来将数据从app发送到...

网友评论

      本文标题:Redux基础

      本文链接:https://www.haomeiwen.com/subject/dcqjbqtx.html