Learn Redux

2018-01-31  本文已影响23人  szu_bee

Redux

const counter = (state = 0, action) => {
  switch (action.type) {
    case 'INCREMENT':
      return state + 1
    case 'D........':
      return state - 1
    default:
      return state
  }
}

// pre writing
const { createStore } = Redux
const store = createStore(counter)

// now writing 
// [ Implementing store from scratch ]
const createStore = (reducer) => {
  let state
  let listeners = []
  
  const getState = () => state;
  
  const dispatch = (action) => {
    state = reducer(state, action)
    listeners.forEach(listener => listener())
  }
  
  const subscribe = (listener) => {
    listeners.push(listener)
    return () => {
      listeners = listeners.filter(l => l !== listener)
    }
  }
  
  dispatch({})
  
  return { getState, dispatch, subscribe }
}


const render = () => {
  document.body.innerText = store.getStatr()
}

store.subscribe(render)
render()

document.addEventListener('click', () => {
  store.dispatch({ type: 'IN....' })
})

Redux 和 reduce 的联系与区别

总结一下 Redux 和 reduce 的联系与区别。

相同点:

不同点:

由上可知,Redux将所有的事件都抽象为 action,无论是用户点击、Ajax请求还是页面刷新,只要有新的事件发生,我们就会 dispatch 一个 action给 reducer,并结合上一次的状态计算出本次状态。抽象出来的统一的事件接口,简化了处理事件的复杂度。

Redux还规范了事件流——单向事件流,事件 action 只能由 dispatch函数派发,并且只能通过 reducer 更新系统(网页)的状态 state,然后等待下一次事件。这种单向事件流机制能够进一步简化事件管理的复杂度,并且有较好的扩展性,可以在事件流动过程中插入 middleware,比如日志记录、thunk、异步处理等,进而大大增强事件处理的灵活性。

上一篇下一篇

猜你喜欢

热点阅读