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

首頁 > 語言 > JavaScript > 正文

讓Vue也可以使用Redux的方法

2024-05-06 15:33:56
字體:
來源:轉載
供稿:網友

上周末看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>

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 东方市| 青阳县| 麻江县| 麻栗坡县| 托克逊县| 沈丘县| 日土县| 庆元县| 罗田县| 攀枝花市| 青海省| 深水埗区| 福泉市| 仙游县| 贵德县| 越西县| 崇明县| 宣化县| 临武县| 宿迁市| 南江县| 海门市| 沾化县| 平山县| 宁海县| 会同县| 河北区| 阳谷县| 文安县| 和平县| 普兰店市| 崇文区| 南宫市| 福泉市| 寿宁县| 蒙山县| 贡山| 姚安县| 惠州市| 淮南市| 濉溪县|