国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

讓Vue也可以使用Redux的方法

2019-11-19 13:47:30
字體:
來源:轉載
供稿:網友

上周末看Vuex源碼,突發靈感,為什么都是Vuex啊。

于是蛋疼一下午寫了一個插件來幫助Vue可以使用Redux

Gayhub Url

Vue-with-Redux

這是一個用于幫助Vue使用Redux管理狀態的插件。Redux是一個非常流行的狀態管理工具。vue-with-redux為大家提供一個可以在Vue環境下使用Redux的途徑。這回帶來不同的開發體驗。

開始

首先你需要通過如下命令安裝vue-with-redux

npm install -save vue-with-redux

運行Demo

 git clone https://github.com/ryouaki/vue-with-redux.git npm install npm run serve

Usage

需要像下面這樣改造你的入口文件:

 // 有可能是你的entry.js文件 ... // 這里是你引入的其它包 import VuexRedux from 'vue-with-redux'; import { makeReduxStore } from 'vue-with-redux'; import reduces from 'YOUR-REDUCERS'; import middlewares from 'REDUX-MIDDLEWARES'; Vue.use(VuexRedux); let store = makeReduxStore(reduces, [middlewares]); new Vue({ store, render: h => h(App) }).$mount('#app')

下面是一個actionCreate函數:

 export function test() { return {  type: 'TEST' } } export function asyncTest() { return (dispatch, getState) => {  setTimeout( () => {  console.log('New:', getState());  dispatch({type: 'TEST'});  console.log('Old', getState());  }, 100); } }

Note: 你并不需要使用redux-thunk,因為Vue-with-Redux已經提供了對異步處理的支持.

這是一個reducer的例子:

 function reduce (state = { count: 0 }, action) { switch(action.type) {  case 'TEST':  state.count++;  return state;  default:  return state; } } export default { reduce };

Vue的組件例子:

 <template> <div>  <button @click="clickHandler1">Action Object</button>  <button @click="clickHandler2">Sync Action</button>  <button @click="clickHandler3">Async Action</button>  <p>{{reduce.count}}</p> </div> </template> <script> import { test, asyncTest } from './../actions'; export default { name: 'HelloWorld', props: {  msg: String }, // 你必須在這里預先定義你訂閱的Redux中的狀態。否則編譯模版會報錯。 data() {  return {  reduce: {}  } }, methods: {  clickHandler1() {  this.dispatch({type: 'TEST'});  },  clickHandler2() {  this.dispatch(test());  },  clickHandler3() {  this.dispatch(asyncTest());  },  // 你必須實現一個mapReduxState函數,用于告訴Vue-with-Redux你需要訂閱哪些redux中的狀態  // [ state ] 參數就是redux狀態樹的根。  mapReduxState(state) {   return {   reduce: state.reduce  }  }, } } </script>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 资中县| 本溪市| 天等县| 沁水县| 洪泽县| 筠连县| 乌兰浩特市| 宜章县| 海口市| 鹤山市| 略阳县| 五原县| 兴和县| 宁安市| 莱阳市| 闸北区| 太谷县| 虞城县| 阿城市| 安康市| 昌邑市| 临潭县| 临澧县| 东丽区| 象州县| 潼关县| 乐清市| 田阳县| 临夏市| 高碑店市| 东平县| 晋宁县| 达孜县| 清新县| 广东省| 桃源县| 正宁县| 邹城市| 稻城县| 临夏县| 眉山市|