vue+vuex+axios从后台获取数据存入vuex,组件之间共享数据

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue+vuex+axios从后台获取数据存入vuex,组件之间共享数据相关的知识,希望对你有一定的参考价值。

在vue项目中组件间相互传值或者后台获取的数据需要供多个组件使用的情况很多的话,有必要考虑引入vuex来管理这些凌乱的状态,今天这边博文用来记录这一整个的过程,后台api接口是使用webpack-server模拟的接口,这个前面的文章中有提到,需要的可以去翻阅。

整个的流程是在组件的created中提交dispatch,然后通过action调用一个封装好的axios然后再触发mutation来提交状态改变state中的数据,然后在组件的计算属性中获取state的数据并渲染在页面上

首先新需要在项目中安装vuex:

运行命令 npm install vuex --save-dev

在项目的入口js文件main.js中

import store from ‘./store/index‘

并将store挂载到vue上

new Vue({
  el: ‘#app‘,
  router,
  store,
  template: ‘<App/>‘,
  render: (createElement) => createElement(App)
})



这里我新建了文件夹fetch用来编写所有的axios处理和axios封装

在fetch文件夹下新建api.js文件:

import axios from ‘axios‘

export function fetch(url, params) {
    return new Promise((resolve, reject) => {
        axios.post(url, params)
            .then(response => {
                 alert(‘Api--ok‘);
                resolve(response.data);
            })
            .catch((error) => {
              console.log(error)
               reject(error)
            })
    })
}

export default {
  // 获取我的页面的后台数据
  mineBaseMsgApi() {
     alert(‘进入api.js‘)
    return fetch(‘/api/getBoardList‘);
  }
}

在store的入口文件index.js中:

 

import Vue from ‘vue‘
import Vuex from ‘vuex‘

import mine from ‘./modules/mine‘;

Vue.use(Vuex);

export default new Vuex.Store({
  modules: {
    mine
  }
});

在你需要请求后台数据并想使用vuex的组件中的created分发第一个dispatch:

created() {
    this.$store.dispatch(‘getMineBaseApi‘);
  }

然后在store/modules下的对应模块js文件中,这里我使用的mine.js文件中编写state、action和mutation

import api from ‘./../../fetch/api‘;
import * as types from ‘./../types.js‘;

const state = {
  getMineBaseMsg: {
    errno: 1,
    msg: {}
  }
}

const actions = {
  getMineBaseApi({commit}) {
    alert(‘进入action‘);
    api.mineBaseMsgApi()
    .then(res => {
        alert(‘action中调用封装后的axios成功‘);
        console.log(‘action中调用封装后的axios成功‘)
        commit(types.GET_BASE_API, res)
    })
  }
}

const getters = {
  getMineBaseMsg: state => state.getMineBaseMsg
}

const mutations = {
  [types.GET_BASE_API](state, res) {
    alert(‘进入mutation‘);
    state.getMineBaseMsg = { ...state.getMineBaseMsg, msg: res.data.msg }
    alert(‘进入mutations修改state成功‘);
  }
}

export default {
  state,
  actions,
  getters,
  mutations
}

 然后在想取回state的组件中使用mapGetters获取state:

import { mapGetters } from ‘vuex‘;

export default {
  ...
  computed: {
    ...mapGetters([
      ‘getMineBaseMsg‘
    ])
  },
  ...      
}

然后在控制台查看把:

getter和mutation都已经成功了,同时我在提交state的整个过程都添加了alert,大家可以看看整个流程是如何走的;

来源: http://www.cnblogs.com/jasonwang2y60/

  

 

  

  





以上是关于vue+vuex+axios从后台获取数据存入vuex,组件之间共享数据的主要内容,如果未能解决你的问题,请参考以下文章

如何从 vue.js axios POST 在 Laravel 中获取 JSON?

前端Vue框架 05 第三方插件(vuex: 组件间交互的(移动端), axios - 前后台(django): ajax, element-ui: 页面布局, jq+bs: jQuery+Boo

Vue 前后台交互,插件

Vue---从后台获取数据vue-resource的使用方法

vue-vuex

已配置好的vue全家桶项目router,vuex,api,axios,vue-ls,async