zoukankan      html  css  js  c++  java
  • Redux实现原理解析及应用

    1,为什么要用redux

    在React中,数据在组件中是单向流动的,数据从一个方向父组件流向子组件(通过props),所以两个非父子组件之间通信就相对麻烦,redux的出现就是为了解决state里面的数据问题。

    2,Redux设计理念

    Redux是将整个应用状态存储到一个地方上称为store,里面保存着一个状态树store tree,组件可以派发(dispatch)行为(action)给store,而不是直接通知其他组件,组件内部通过订阅store中的状态state来刷新自己的视图。
    ~~~~
    <img id="img1566815573345" src="file:///Users/luhua/Library/Application Support/xiangxuema/xxm/5/img1566815573345.png"  data-tomark-pass />
    ## 3,Redux三大原则
    
        1. 唯一数据源
        2. 保持只读状态
        3. 数据改变只通过纯函数来执行
      1,唯一数据
      ~~~~
      整个应用的state都被存储到一个状态树中,并且这个状态树,只存在于唯一的store
      ~~~~
      2,保持只读状态
      ~~~~
       state是只读的,唯一改变state的方法就是触发action,action是一个用于描述以发生时间的普通对象
      ~~~~
      3,数据改变只能通过纯函数来执行
      ~~~~
       使用纯函数来执行修改,为了描述action如何改变state的,需要编写reducers
      ~~~~
    ## 4,Redux概念解析  
      
    ###   4.1,Store
    
    1.   store就是保存数据的地方,可以把它看成一个数据,整个应用只能有一个store
    2.   Redux提供createStore这个函数,用来生成Store
    ### 4.2 State
        state 就是store里面存储的数据,store里面可以拥有多个state,redux规定一个state对应一个View,只要store相同,view就是一样的,反过来也是一样的。通过store.getState()获取
    ## 4.3 Action
        state的改变会导致View的变化,但是在redux中不能直接操作state也就是说不能使用this.setState来操作,用户只能接触到view.在redux中提供一个对象来告诉Store需要改变state。
    Action是一个对象其中type属性是必须的,表示Action的名称,其他的可以根据需求自由设置。
    const action = { type: "ADD_TODO", payload: "redux原理" } ## 4.4 store.dispatch() store.dispatch()是View发出Action的唯一办法 store.dispath({ type: "ADD_TODO", payload: "redux原理" }) store.dispatch接收一个Action作为参数,将它发送给store通知store来改变state ## 4.5 Reducer Store收到Action以后,必须给出一个新的state,这样view才会发送变化。这种state的计算过程就叫做Reducer. Reducer是一个纯函数,他接收Action和当前state作为参数,返回一个新的state。 注意:Reducer必须是一个纯函数,也就是说函数返回的结果必须由参数state和action决定,而且不产生任何副作用也不能修改state和action对象 const reduer = (state,action) => { switch(action.Type) { case ADD_TODO: return newState; default return state } } ## 5 Redux源码 let createStore = (reducer) => { let state; //获取状态对象 //存放所有的监听函数 let listeners = []; let getState = () => state; //提供一个方法供外部调用派发action let dispath = (action) => { //调用管理员reducer得到新的state state = reducer(state, action); //执行所有的监听函数 listeners.forEach((l) => l()) } //订阅状态变化事件,当状态改变发生之后执行监听函数 let subscribe = (listener) => { listeners.push(listener); } dispath(); return { getState, dispath, subscribe } } let combineReducers=(renducers)=>{ //传入一个renducers管理组,返回的是一个renducer return function(state={},action={}){ let newState={}; for(var attr in renducers){ newState[attr]=renducers[attr](state[attr],action) } return newState; } } export {createStore,combineReducers};
  • 相关阅读:
    webpack 入门
    javascript 函数重载另一种实现办法
    5个python爬虫教材,让小白也有爬虫可写,含视频教程!
    简书模拟登陆缺陷!!!
    Python操作Mongodb
    【爬虫系列之一】爬虫开发环境的搭建
    CentOS7.4,anaconda3,python3.6,tensorflow环境下gdal的编译和问题解决
    返回Json格式结果
    json扩展
    EF中使用SQL语句或存储过程
  • 原文地址:https://www.cnblogs.com/setbug/p/14480207.html
Copyright © 2011-2022 走看看