Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >React进阶(2)-上手实践Redux-如何获取store的数据

React进阶(2)-上手实践Redux-如何获取store的数据

原创
作者头像
itclanCoder
修改于 2020-10-23 09:56:13
修改于 2020-10-23 09:56:13
2.3K00
代码可运行
举报
文章被收录于专栏:itclanCoderitclanCoder
运行总次数:0
代码可运行

前言

在前面的一文理解Redux中,已经知道了Redux的工作流程以及Redux的设计基本原则,它就是一个用于管理组件的公共数据状态的数据层框架,包括了Store,Reducer,React Component,Actions Creators四个部分

其中核心是Store,他们彼此之间的关系对于写Redux是非常重要的,宏观上讲:也可以将Redux=reducer+Flux的组合,代码就是文字描述的最佳的体现,解释

你将在本文学习到

  • 编写Redux的的基本流程
  • 如何获取store中公共的数据,并展示到页面上
  • 如何更改store的公共数据,实现组件的数据与store的同步更新
  • ....更多的细节见下文

下面就一起来编写Redux代码的,以下是最终实现的效果图,添加,删除列表操作

使用Ant-design布局todolist

对于初学者,一个简单的todolist例子对于入门redux是一个非常好的实践,这就好比刚写程序时的Hello-world,虽然麻雀虽小,但是五胀俱全 在React中要使用Redux时,必须先要在命令行终端下进行安装

  • 使用npm或者cnpm,yarn(使用yarn时,需要先安装它,然后才可以使用)进行安装
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
yarn add redux
// 或者
npm install --save redux

安装完后,可以在根目录下package.json查看到redux的版本,如果有,说明已经安装成功了的

  • ant-design的使用可以参考官方文档https://ant.design/docs/react/introduce-cn
  • 同样也是需要先安装,然后在项目中使用
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
yarn add antd

然后在index.js中引入样式

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import 'antd/dist/antd.css'

当然你也可以按需加载组件的方式,具体配置可以参照官方文档

以下是index.js代码

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import React from 'react';
import ReactDOM from 'react-dom';
import { Input, Button, List } from 'antd'; // 引入antd组件库
import 'antd/dist/antd.css'; // 引入antd样式

// TodoList组件
class TodoList extends React.Component {
  constructor(props){
    super(props);
    // 组件内部的初始化状态数据
    this.state = {
      inputValue: 'itclanCoder', // input表单初始值
      list: ['itclanCoder', '川川', '学习Redux'] // 下方列表展示的数据
    }
  }
    render() {
        return (
            <div style={{ margin: "10px 0 0 10px"}}>
                    <div>
                        <Input value={this.state.inputValue} style={{ width:"300px",marginRight:"10px"}} placeholder="请输入内容..." />
                        <Button type="primary">提交</Button>
                    </div>
                    <List
                      style={{ width: '300px',marginTop:'10px'}}
              bordered
              dataSource={this.state.list}
              renderItem={item => <List.Item>{item}</List.Item>}/>
            </div>
        )
    }
}
const container = document.getElementById('root');

ReactDOM.render(<TodoList />, container);

最终渲染的UI效果如下所示:

在控制台中可以多查看组件state的各个状态的,有助于理解React的

在上面的代码中,我们发现组件内部的状态数据是放在当前组件的state进行存储管理的,对于这种小的demo例子,杀鸡焉用宰牛刀使用Redux未免有些大才小用

但是如果组件非常的业务逻辑非常复杂,状态特别多,那么使用Redux的优点就非常明显了的

下面引入redux,同样能够达到同样的效果,放上上一节的理解Redux的工作流程图

(代码是次要的,理解上面这张Redux工作流程图很重要)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import React from 'react';
import ReactDOM from 'react-dom';
import { Input, Button, List } from 'antd'; // 引入antd组件库
import 'antd/dist/antd.css'; // 引入antd样式

// 1. 创建一个store管理仓库,从redux库中引入一个createStore函数
import { createStore } from 'redux';

// 2. 引入createStore后,store并没有创建,需要调用createStore()后才有store
const store = createStore(reducer); // 创建好reducer后,需要将reducer作为参数传到createStore当中去,这样store才能拿到reducer的state数据

// 3. 创建reducer函数,管理组件共享的数据状态以及一些动作
// reducer是一个纯函数,返回一个新的state给store
// 4. 初始化state值,将原先组件内部的状态的数据,移除到reducer里面去管理
function reducer(state = {
    inputValue: 'itclanCoder',
    list: ['itclanCoder', '川川', '学习Redux']
}, action){
    return state;
}

// TodoList组件
class TodoList extends React.Component {
    constructor(props){
        super(props);
        // 5. 在组件内部通过getState()方法就可以拿到store里面的数据,该方法能够获取到store上存储的所有状态
        this.state = store.getState();
        
    }
    render() {
        return (
            <div style={{ margin: "10px 0 0 10px"}}>
                    <div>
                        <Input value={this.state.inputValue} style={{ width:"300px",marginRight:"10px"}} placeholder="请输入内容..." />
                        <Button type="primary">提交</Button>
                    </div>
                    <List
                      style={{ width: '300px',marginTop:'10px'}}
                      bordered
                      dataSource={this.state.list}
                      renderItem={item => <List.Item>{item}</List.Item>}/>
            </div>
        )
    }
}
const container = document.getElementById('root');

ReactDOM.render(<TodoList />, container);

上面的实例代码中,完成了将原先定义在组件内部的状态数据抽离到Redux中的reducer去管理,在当前组件内部通过getState()方法拿到state数据,最终渲染到页面上

梳理一下Redux的使用流程:

1.  命令行终端下安装redux第三方库

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
yarn add redux

2. 在项目中引入redux库,同时创建一个store仓库,这是通过调用createStore函数实现的

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import { createStore } from 'redux';
const store = createStore(); // 调用createStore函数才会真正的创建一个store

3. 创建reducer函数,用于存储公共组件的数据状态,它是一个纯函数,用于返回组件的状态

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/*
 reducer是一个纯函数,接收两个参数,state和action其中state存储的就是组件的公共状态的,而action就是组件派发的动作,reducer的最终结果是由state和action共同决定的,后面会接着讲action
*/
function reducer(state, action){
    return state
}

4. 在reducer创建好之后,需要把reducer传递给createStore函数当中去,这样store就拿到了reducer里面的数据,这一步是必须要做的,否则就会拿不到reducer中state的数据

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const store = createStore(reducer); // reducer函数必须传递给createStore函数中去,否则页面无法获取store的数据

5. 组件内如何获取store中数据,通过调用getState方法获取store中的数据,该方法能够获取到store上存储的所有状态,该方法放置的位置是在constructor函数里面

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
this.state = store.getState(); // getState方法能够获取store中的所有状态

6. 组件的渲染

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<Input value={ this.sate.inputValue }>
<List dataSource={this.state.list} />

上面的过程:其实完成的就是Redux工作流中的右边的内容

整个过程总结几句话就是:

引入redux库,并调用createStore函数,从而创建了store,紧接着创建reducer函数,用于管理组件公共的状态数据,返回组件的最新的状态数据给store

其结果由state和action共同决定,然后将创建的reducer函数作为参数,让createStore函数接收.

进而store就获取到了reducer函数里面的组件公共存储的数据,当组件外部想要拿store的公共数据时

于是引入store,并通过getState这个函数就可以获取store中的所有数据,最终可将数据渲染到页面上

结语

本文并不是什么高大上的内容,主要是对学习Redux的一个小小的初探

用几句简单归纳下:组件如何获取store中的数据

  • 安装redux,然后从redux中引入createStore这个方法,并调用它,从而创建store,
  • 紧着在创建reducer纯函数,在reducer里面进行state的逻辑操作,reducer的返回值取决于state与action这个的决定,最终该函数返回最新结果会返回给store,完成新旧数据的替换,
  • 而在组件中如何获取store的数据,是通过getState方法进行获取store中的所有状态

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
React进阶(3)-上手实践Redux-如何改变store中的数据
在前面的一文React进阶(2)-上手实践Redux-如何获取store的数据当中,已经知道组件怎么获取store的数据,并渲染到页面上,那么在该节当中揭示怎么更改store的数据,实现页面的更新
itclanCoder
2020/10/23
2.6K0
React进阶(4)-拆分Redux-将store,Reducer,action,actionTypes独立管理
在前面的几小节中已经完成了一个todolist的添加,删除的操作,通过把组件的数据放到了Redux中的公共存储区域store中去存储,在Redux中进行状态数据的更新修改
itclanCoder
2020/10/25
2K0
React-Redux入门
ant design https://ant.design/docs/react/introduce-cn
Java架构师必看
2021/03/22
6760
React-Redux入门
React进阶(5)-分离容器组件,UI组件(无状态组件)
至今为止,关于React中的组件已经接触到了有很多,用类class声明的组件,函数式funtion关键字声明的组件,以及样式组件(styled-components),对于前面几节当中已经用Redux实现了一个todolist,但是代码依旧不够完美,我们继续进行拆分的
itclanCoder
2020/10/25
1.5K0
使用Redux制作一个TodoList
在组件化开发的 web 前端当中,经常的需要在不同的组件之间进行通信以及一些数据共享,那么我们就需要使用像 Vuex 那样的状态管理工具,在 React 当中,经常使用 Redux 来做状态管理工具。
小小杰啊
2022/12/21
4670
使用Redux制作一个TodoList
React进阶(6)-react-redux的使用
image.png 前言 您将在本文当中学习到 react-redux是什么,解决什么问题 UI组件以及容器组件 react-redux中两个重要的API,Provider以及connect mapS
itclanCoder
2020/10/25
2.2K0
06-React状态管理 Redux(工作流程, 核心概念, 求和案例, 异步Action, React-Redux, 多状态管理, 纯函数, 高阶函数, Redux开发者工具)
其实就是一个集中的状态管理技术, 类似于VueX, 以及后端的分布式配置中心, 在前端的文章里提后端,是不是不太好~, 但是能学习这个技术的人, 从简短的一句话中应该就已经简单的了解了这个技术,以及它的使用情况, 我就不过多写概念了, 主要写使用方式
彼岸舞
2022/08/24
2K0
06-React状态管理 Redux(工作流程, 核心概念, 求和案例, 异步Action, React-Redux, 多状态管理, 纯函数, 高阶函数, Redux开发者工具)
React结合Redux实现Todolist
使用了redux进行状态管理 删除一个用户首先dispatch了一个deleteTodoList的 action  然后在reducer中返回删除后的数据 store更新数据 组件订阅了store的更新后 更新了内部状态 页面更新成功
憧憬博客
2020/07/20
5150
【案例】使用React+redux实现一个Todomvc
❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…❤️…
且陶陶
2024/07/25
750
【案例】使用React+redux实现一个Todomvc
react全家桶包括哪些_react 自定义组件
对于现在比较流行的三大框架都有属于自己的脚手架(目前这些脚手架都是使用node编写的,并且都是基于webpack的):
全栈程序员站长
2022/11/18
5.9K0
react全家桶包括哪些_react 自定义组件
Redux/react-redux/redux中间件设计实现剖析
在一切开始之前,我们首先要回答一个问题:为什么我们需要redux,redux为我们解决了什么问题?只有回答了这个问题,我们才能把握redux的设计思路。
Nealyang
2020/04/23
2.3K0
Redux/react-redux/redux中间件设计实现剖析
Redux 快速上手指南
如果要用一句话来概括Redux,那么可以使用官网的这句话:**Redux是针对JavaScript应用的可预测状态容器。**此句话虽然简单,但包含了以下几个含义:
xiangzhihong
2022/11/30
1.3K0
深入理解 Redux 原理及其在 React 中的使用流程
大家好,我是腾讯云开发者社区的 Front_Yue,随着前端开发技术的不断发展,开发者们越来越注重应用的可维护性、可扩展性和稳定性。而状态管理库 Redux 的出现,为我们的应用提供了一种优雅的状态管理方案。本篇文章将详细介绍 Redux 的原理以及如何在 React 项目中使用 Redux。
Front_Yue
2024/06/10
3690
深入理解 Redux 原理及其在 React 中的使用流程
React 入门学习(十四)-- redux 基本使用
在了解了 Antd 组件库之后,我们现在开始学习了 Redux ,在我们之前写的案例当中,例如:todolist 案例,GitHub 搜索案例当中,我们对于状态的管理,都是通过 state 来实现的,比如,我们在给兄弟组件传递数据时,需要先将数据传递给父组件,再由父组件转发 给它的子组件。这个过程十分的复杂,后来我们又学习了消息的发布订阅,我们通过 pubsub 库,实现了消息的转发,直接将数据发布,由兄弟组件订阅,实现了兄弟组件间的数据传递。但是,随着我们的需求不断地提升,我们需要进行更加复杂的数据传递,更多层次的数据交换。因此我们为何不可以将所有的数据交给一个中转站,这个中转站独立于所有的组件之外,由这个中转站来进行数据的分发,这样不管哪个组件需要数据,我们都可以很轻易的给他派发。
小丞同学
2021/09/30
5810
React 入门学习(十四)-- redux 基本使用
React---Redux的基础使用
   3.例子:{ type: 'ADD_STUDENT',data:{name: 'tom',age:18} }
半指温柔乐
2021/04/30
7850
React---Redux的基础使用
React 如何使用Redux的说明
React和Redux是两个非常流行的JavaScript库,用于构建Web应用程序。React用于构建用户界面,而Redux用于管理应用程序的状态。在本文中,我将详细介绍React和Redux的使用,并演示如何将它们结合使用来构建复杂的Web应用程序。
世间万物皆对象
2024/03/20
1210
Redux 入门到高级教程
Redux 是 JavaScript 状态容器,提供可预测化的状态管理。 (如果你需要一个 WordPress 框架,请查看 Redux Framework。)
老马
2019/05/25
2.7K0
react+redux+webpack教程3
现代web页面里到处都是ajax,所以处理好异步的代码非常重要。 这次我重新选了个最适合展示异步处理的应用场景——搜索新闻列表。由于有现成的接口,我们就不用自己搭服务了。 我在网上随便搜到了一个新闻服务接口,支持jsonp,就用它吧。 一开始,咱们仍然按照action->reducer->components的顺序把基本的代码写出来。先想好要什么功能, 我设想的就是有一个输入框,旁边一个搜索按钮,输入关键字后一点按钮相关的新闻列表就展示出来了。 首先是action,现在能想到的动作就是把新闻列表放到仓库里,
前朝楚水
2018/04/03
1K0
React/ReactNative 状态管理: redux 如何使用
有同学反馈开发 ReactNative 应用时状态管理不是很明白,接下来几篇文章我们来对比下 React 及 ReactNative 状态管理常用的几种框架的使用和优缺点。
张拭心 shixinzhang
2023/03/27
1.4K0
React-Redux 100行代码简易版探究原理。
各位使用 react 技术栈的小伙伴都不可避免的接触过redux + react-redux的这套组合,众所周知 redux 是一个非常精简的库,它和 react 是没有做任何结合的,甚至可以在 vue 项目中使用。
ssh_晨曦时梦见兮
2020/10/15
7030
推荐阅读
相关推荐
React进阶(3)-上手实践Redux-如何改变store中的数据
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文