redux.js详解及基本使用
什么是Redux
"color: #ff0000">为什么要用
Action:action是一个事件,用来描述发生了什么事,例如用户点击了一个刷新按钮,就会产生一个获取最新数据的事件,Action就是用来标识这个事件的,Action是一个JS对象,拥有2个属性,一个type,一个data,type用来表示该action的类型,data为新的状态数据,既然是对象当然还可以带上一些其他的属性,在处理状态的时候使用。
Reducer:reducer是一个处理状态的函数,真正的状态数据处理就是在这个函数里,reducer接受两个参数,一个是修改前的状态(state)对象,一个是action。可以在reducer中判断action的type属性来确定是一个什么事件然后对state做相应的处理,并返回新的state。
Store:store是Redux的CPU,状态处理器,它提供了一些api给我们使用,如:
getState方法,可以获取到最新的状态对象树。
subscribe方法用来订阅状态的更新,该方法接受一个函数做为监听器,并会返回一个注销订阅的函数,以便我们在不需要订阅时注销改监听器。
dispatch方法用来分发事件,它接受一个action作参数,把事件发出去。
State:state是存储的数据,数据会以对象树的结构来管理,这里要注意,Store每次传给reducer的state是整个state对象树中对应该reducer名字(key)的子对象。
"htmlcode">
1、先是安装reduxJx, cnpm i --save rudux 2、创建一个store的js文件 3、使用import来引用 redux import { createStore } from 'redux' 4、然后在store 创建一个全局管理数据对象 const preloadState = { cartList: [] } 5、处理全局数据的方法 const reducer = function(state, action){ // 参数state:上一次的state状态 // 参数action:事件描述对象 console.log(action.type); 处理数据方法 if (item.a === 0 ){ ...代码 } //返回下一次全局使用的state状态 return state; } //创建仓库 const store = createStore(reducer, preloadState); export default store 6、dispatch的使用 在store以外 store.dispatch()调用 参数1:设置store里面的action相对的type值,参数2:传递的数据 如下: store.dispatch({ type: 'add', value: { id: 2 } }) 然后在store里面的action里面可以获取到 type和传入的value值,也可以在全局管理数据中的state改变全局的数据 7、在组件(页面)中也可以通过store. getState()来获取你存储的相对应的值, 8、store.subscribe()的操作是基本用来监听 store里面的一些数据变化进行操作的,需要主要的是dispatch的操作顺序,
总结
以上所述是小编给大家介绍的redux.js详解及基本使用,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
下一篇:javascript获取元素的计算样式