理解Redux以及如何在项目中的使用

  今天我们来聊聊Redux,这篇文章是一个进阶的文章,建议大家先对redux的基础有一定的了解,在这里给大家推荐一下阮一峰老师的文章: http://www.ruanyifeng.com/blog/2016/09/redux_tutorial_part_one_basic_usages.html

对于基础部分我在这里稍微讲解一下

  首先我们要知道我们为什么要使用Redux,我们在什么情况下才需要去使用Redux,在这里引用Redux的创造者的一句话:"只有遇到 React 实在解决不了的问题,你才需要 Redux 。" 

  结合项目经验说下我自己的理解:如果这批数据只是在一个组件使用并且不需要和别的组件进行数据共享,从单一来源获取数据的时候,也就是说你的UI层很简单,没有复杂的数据流动,总之就是加入数据流动单项并且很简易,没有与服务器的大量交互的情况下,我们不需要使用Redux,否则只会让我们的开发变得更加复杂。

  那么什么时候我们需要用到Redux呢:比如你的数据流动很复杂,这批数据有多个组件需要使用甚至别的页面也需要使用它,或者说就是你的某些状态需要在多个没有强关联的组件中用到,举个很常见的例子,就比如说我们做登录保存用户信息或者是做购物车的时候,我们就很有必要引入Redux来帮我们做状态管理了,总之,就是在你某些状态或者数据的很难控制很难传递的时候,你需要Redux来帮助你。

参照这张经典图来讲解一下Redux的工作原理

  组件Component通过ActionCreators派发一个行为action(注意在这里是派发一个扁平对象),这个行为被派发到了Store,Store借助Reducer确认该State的状态并执行相应的操作,接下来Reducer把新的State返回给Store,最后Store把这个State转给了Component。

假如说你已经在你使用Redux做过一些小demo了,我讲一下在项目中的一个Redux进阶用法,我就根据上面讲的Redux的工作流程,结合伪代码给大家讲解一下在项目中我们应该如何去使用它(建议把这段伪代码通读几遍,因为本人写的前后顺序排的不是很合理,但是通读下来几遍的话,相信你能理解的):

  第一步:我们要在最外面注册一个Store

import { createStore, applyMiddleware } from ‘redux‘    //applyMiddleware作用是提供一个中间件,关于Redux中中间件的理解大家可以去官网看一下,很有用处,链接地址:http://cn.redux.js.org/docs/advanced/Middleware.html
import thunk from ‘redux-thunk‘ //可以让dispatch传的内容就不会局限于只能传一个扁平对象了,就可以传一个函数了,关于redux-thunk的话后期我给大家写一个它源码的解析,最近太累了,感兴趣的伙伴先自己查查
import reducers from ‘./reducers‘  

const store = createStore(reducers,applyMiddleware(thunk))   

export default store

  第二步:可能你会有很多个地方要用到Redux,那么你可能会有很多reducer,这个时候我们会需要redux提供的combineReducers来将我们各个地方的reducer进行合并,就会让它们互不影响

import { combineReducers } from ‘redux‘ //为了可以引入多个reducer
//以下是伪代码,只是模拟我们有多个reducer,我们可以把它们合并起来,互不影响
import {reducer as  first} from ‘pages/first‘
import {reducer as ticket} from ‘pages/ticket‘

export default combineReducers({
    first,
    ticket
})

  第三步:全局注入store

import { Provider } from ‘react-redux‘    //你可以Provider想象成一个注入器,它可以帮我们把store注入到我们的根组件上,这样的话store将无处不在
import store from ‘./store‘
ReactDOM.render(
    <Provider store={store}>
        <App />
    </Provider>,
    document.getElementById(‘root‘)
)

  接下来就是我们某个地方要如何使用Redux,假设现在的场景是这样的,我们要派发一个action,同时这个action还要去请求ajax,ajax又是异步的,这个时候我们刚才的那个thunk就有作用了,我先简单讲解一下它的作用,我们通常情况下是提交一个扁平对象,然后这个action直接送到reducer中去进行操作,但是我们有异步请求数据的时候怎么办呢,thunk给我们提供的就是我们派发行为的时候可以派发一个函数,再派发一个扁平对象,当遇到函数的时候会先执行函数里面的内容最后再去提交到reducer中,好,大概你应该懂我的意思了,开始操作:

 

第四步:我们要触发action对吧,为了避免命名冲突,我们先来创建一个actionTypes.js文件,我们要给每个type加一个命名空间:

export const GET_COMMENT_DATA = ‘ticket/get_comment_data‘

export const SET_RECORD_DATA = ‘ticket/set_record_data‘

  

  第五步:我们要去派发一个action,直接把怎么拿store中的数据也写出来把

const mapDispatch = (dispatch)=>{
  return {
      loadList(){
          dispatch(loadListDataAsync(dispatch))
      }
  }
}
const mapState = (state) => {
    return {
      swiperList: state.first.list
    }
}

  

  第六步:我们要从react-redux中引入一个connect,它是帮助我们来可以在组件中使用dispatch和state的,写法是这样的:

export default connect(mapState,mapDispatch)(App)记录下我之前遇到的一个小坑,之前我是只在当前组件中用到了dispatch,所以我是这样写的:
export default connect(mapDispatch)(App)      //后来发现会有一堆红色的怪物包围着我
正确的姿势其实是这样的:
export default connect(null,mapDispatch)(App)

  

  第七步:我们去看看我们是怎么利用thunk请求ajax数据的把:

import { GET_COMMENT_DATA } from ‘./actionTypes‘

export const LoadCommentDataAsync = (dispatch,id)=>{        
    return ()=>{              //在这个函数中我们可以进行异步请求数据
        fetch(‘/haha‘, {
            method: ‘GET‘,
            headers: {
                ‘content-type‘: ‘application/json‘
            },
        })
        .then(response => response.json())
        .then(result=>{
            dispatch({            //遇到扁平对象了,可以提交到reducer了
              type: GET_COMMENT_DATA,
              comments: result
          })
        })
    }
}

  

  第八步:我们来到reducer中处理你的action

import { GET_COMMENT_DATA } from ‘./actionTypes‘
import { SET_RECORD_DATA } from ‘./actionTypes‘

const defaultState = {
    comments: {},
    records: []
}

export default (state=defaultState,action)=>{
    if(action.type === GET_COMMENT_DATA){
        return {
            ...state,
            comments: action.comments
        }
    }
    if(action.type === SET_RECORD_DATA){
        return {
            ...state,
            records: [...state.records,action.records]
        }
    }
    return state
}

  

  第九步:我们把这个reducer暴露出来,也就是我们第一步在reducers中引入的reducer

import reducer from ‘./reducer‘

export {
    reducer
}

   这篇写的不是很好,原谅我,最近很多事都堆在一起了,等我调整好了,这次的代码就当成全是伪代码来看,重在理解Redux的流程以及它是如何在项目中进行使用的,理解它的用法即可,相信你看懂了以后在写项目的时候会对它的理解会越来越深刻的,别看我代码是怎么写的,就看看步骤就行了,我承认这次写的很烂(:,等我调整好了给大家把注释和解释再完善完善,后期我会来修改它的

原文地址:https://www.cnblogs.com/bai1218/p/10104969.html

时间: 2024-10-10 02:43:49

理解Redux以及如何在项目中的使用的相关文章

理解java Web项目中的路径问题

本文以项目部署在tomcat服务器为例,其他相信也是一样的. 先说明请求页面的写法,在web中,页面路径主要写的有以下几种 1.请求重定向 2.浏览器的请求被服务器请求到新页面(我称为“转发”) 3.超链接 4.form表单提交的action 为了演示路径写法,首先先建一个项目(项目名WebPath),并建立一个servlet(PathServlet) 目录结构如下 以访问目录中index.jsp文件为例,jxf.path.PathServlet.jave中对以上四种路径的写法(红色部分) 1

记录一次线程池的在项目中的实际应用,讲解一下线程池的配置和参数理解。

前言:最近项目中与融360项目中接口对接,有反馈接口(也就是我们接收到请求,需要立即响应,并且还要有一个接口推送给他们其他计算结果),推送过程耗时.或者说两个接口不能是同时返回,有先后顺序. 这时我想到了把自己Controller立即返回接受成功,中间添加一个新的线程去做其他耗时的操作(线程池配置和参数测试讲解请阅读第5步). 1.Controller代码如下: @Autowiredprivate CallThreadDemo worker; @RequestMapping("/bandBank

SLAM+语音机器人DIY系列:(二)ROS入门——8.理解roslaunch在大型项目中的作用

摘要 ROS机器人操作系统在机器人应用领域很流行,依托代码开源和模块间协作等特性,给机器人开发者带来了很大的方便.我们的机器人"miiboo"中的大部分程序也采用ROS进行开发,所以本文就重点对ROS基础知识进行详细的讲解,给不熟悉ROS的朋友起到一个抛砖引玉的作用.本章节主要内容: 1.ROS是什么 2.ROS系统整体架构 3.在ubuntu16.04中安装ROS kinetic 4.如何编写ROS的第一个程序hello_world 5.编写简单的消息发布器和订阅器 6.编写简单的s

React +Redux+ Ant Design + echarts 项目实践

项目框架 采用React.js作为项目的框架 采用redux作为数据管理的框架 采用antd作为项目的UI组件 采用echarts完成项目中折线图的绘制 个人项目工作流程总结 拿到UI高保真图片之后先对整个页面进行模块化分,大的模块分为上部的折现图部分,中间部分的网元的拓扑图部分,下部分表格部分以及表格点击后的弹出层部分.每个模块有可以再次细分为模块的头部(头部数据基本不变化),以及模块的内容展示部分. 基本就这样把整个页面细分成不同的组件模块,子组件又可以组成父组件,大的父组件完整组合成整个页

团队项目中个人的定位及计划

我们团队在这一次的移动APP开发计划中准备做一个针对上海地区大学分数线进行专业推荐的APP,根据前几章的学习,团队中的成员将会被初步分为开发人员.测试人员以及PM(program manager).我在这次的软件开发中担任开发人员的职务. 在开发开始的阶段,全员首先一起明确这次APP的主题,一起分析好这款APP将要实现怎样的功能,将要面向哪些受众:对于市面上的同类软件,我们还能添加哪些实用的功能.首先将会尽可能地将上海地区内高校近几年的分数线.每个系的最低录取分数统计好录入系统中,再根据考生相应

如何去除vue项目中的 # --- History模式

使用vue-cli搭建的环境,在配置好路由之后,可以看到下面的情况: 但是不难发现#的出现真的很丑陋,并且也不知道这是什么作用? 所以就去Stack Overflow上搜索了,果然还有~  看来Stack Overflow是真的强大,你在项目中遇到的问题实际上在so上都已经被问过并且解决了,这不:    这是最高票的回答,即在vue2中将mode模式设置为history,试过之后确实奏效! 但是知道这样可以解决问题,却不知道为什么,这是不行的, 随着连接,我们看到了文档. 所以这篇文章也就是引申

在Unity3D项目中接入ShareSDK实现安卓平台微信分享功能(可使用ShareSDK默认UI或自定义UI)

最近公司的大厅要重做,我协助主程一起制作新大厅和新框架,前面制作的编辑器也派上了用场.等全部功能做完后我会再写一个复盘,这两天主程在忙于写热更新的功能,所以把接入分享SDK功能的任务交给了我,ShareSDK官网的文档比较分散,而且关于Unity的文档比较简略,所以还是有不少的坑.写篇博客分享一下,并加强理解记忆. 第一步,先去ShareSDK的官网下载最新版本的ShareSDK(完全免费).地址:http://www.mob.com/ 我们选择ShareSDK For Unity3D,页面会直

ASP.NET Core项目中新增和删除的内容

最新一版的.NET几经改名,最终得到了.NET Core这个高大上的名称,相应的ASP.NET MVC也跟着提供了ASP.NET Core MVC版本. 在.NET Core没有稳定名称时,叫做MVC6,模糊记得主推的概念就是MCV的controller和API的controller合二为一了,还没来得及深入了解名称就改了. 目前的版本以及名称已经相对成熟,从.NET社区推荐的热点文章来看,都是针对.NET Core给出的使用介绍. 从最近的了解来看,相比之前ASP.NET版本,是一个全新的框架

如何在程序开发项目中选择合适的 JavaScript 框架,节省时间和成本的9款极佳的JavaScript框架介绍

从技术上来看,iOS,Android 和 Windows Phone 上的移动应用是使用不同的程序语言开发的,iOS 应用使用 Objective-C,Android 应用使用 Java,而 Windows Phone 应用使用 .NET. .随着 JavaScript,CSS 和 HTML 知识技能的提升,相信你也可以构建一个超赞的移动应用.在这篇博客里,我们将会介绍一些极好的 JavaScript 移动应用程序开发框架. 说到网络开发,就不得不说 JavaScript,这是一款很有前途的程序