详细讲解vue2+vuex+axios

发布时间 - 2026-01-11 01:26:37    点击率:

在vue2项目中,组件间相互传值或者后台获取的数据需要供多个组件使用的情况很多的情况下(后台获取数据存入vuex,组件之间共享数据),那么就需要用vuex来管理这些。

整个的流程是在组件的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)
 })

然后看下整个store的目录结构,modules文件夹用来将不同功能也面的状态分成模块,index.js文件夹是store的入口文件,types文件夹是定义常量mutation的。文件夹整个vuex的目录结构如下:

这里我新建了文件夹fetch用来编写所有的axios处理(这里是把axios封装了)并且在fetch文件夹下新建api.js文件:

 import axios from 'axios'
 axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
 axios.defaults.baseURL = '后台接口公共前缀';
 export function fetch(url, params) {
  return new Promise((resolve, reject) => {
   axios.post(url, params)
    .then(response => {
    resolve(response.data);
 })
 .catch((error) => {
  reject(error);
  })
 })
 }
 export default {
 // 获取我的页面的后台数据
  mineBaseMsgApi() {
  // alert('进入api.js')
   return fetch('/api/getBoardList');
  },
  commonApi(url, params) {
  return fetch(url, params)
  }
 }

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

 // 组装模块并导出 store 的文件
 import Vue from 'vue'
 import Vuex from 'vuex'
 import mine from './modules/mine';
 import club from './modules/club';
 Vue.use(Vuex);
 // 导出需要的模块
 export default new Vuex.Store({
  modules: {
   club,
   mine
  }
 });

一般在项目中,我们跟在交互的时候,无非是存数据和取数据。首先我们来看存数据:

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

 created() {
  // 保存ID到vuex,在购买页面使用
  this.$store.dispatch('storeMovieID',this.$route.params.ID)——(“action名”,data);
  api.commonApi('url','params')
   .then(res => {
    this.backMsg = res.data;
    console.log(this.backMsg);
    console.log('调用封装后的axios成功');
   })
 },

2:然后在store/modules下的对应模块js文件中,这里我使用的club.js文件中编写state、action和mutation(一般为了方便,我们会习惯的把action里面的名字以驼峰式命名,而mutation里面的命名,我们会采用全大写+下划线的命名方式)actions 用来触发mutations,action可以进行异步操作 ,在action里可以用commit提交mutations

 const actions = {
  // 保存ID storeMovieID为上面的"action名"
  storeMovieID({ commit }, res) {
   //此处是触发mutation的 STORE_MOVIE_ID为"mutation名"
   commit(types.STORE_MOVIE_ID, res);
  },
 }

3:我们需要在type.js里面定义常量:

// ID 变量名(大写)=‘常量名(大写)'
export const STORE_MOVIE_ID = 'STORE_MOVIE_ID';

4:通过mutation修改state中的数据:

//mutation名常量定义 并且需要在type.js文件下定义常量
const mutations = {
 // 修改ID 中括号代表常量 [types.常量名]
 [types.STORE_MOVIE_ID]( state, res) {
  state.movieID = res;  //state.数据名 = data
 },
}

5:定义state数据:(数据名:初始值)

const state = {  //采用 数据名:初始值的格式
 contextPathSrc: '后台接口公共部分',
 movieID: '',
}

最后所有的club.js完整内容如下:(当然getters是在取数据的时候用的,下面会讲)

import api from './../../fetch/api';
import * as types from './../types.js';
// state 是vuex 保存数据的,就相当于vue里的data
const state = {
 contextPathSrc: '后台接口公共部分',
 movieID: '',
}
const actions = {
 // 保存ID storeMovieID为上面的"action名"
 storeMovieID({ commit }, res) {
  //此处是触发mutation的 STORE_MOVIE_ID为"mutation名"
  commit(types.STORE_MOVIE_ID, res);
 },
}
const getters = {
 // 图片公共 src 的获取 getter函数:state=> state.数据名
 getContextPathSrc: state => state.contextPathSrc,
 // 获取ID
 movieID: state => {
  if(state.movieID == ''){
   return localStorage.getItem('STORE_MOVIE_ID');
  }else{
   return state.movieID;
  }
 },
}
//mutation名常量定义 并且需要在type.js文件下定义常量 mutations 用来向state提交数据的,只能进行同步操作
const mutations = {
 // 修改ID 中括号代表常量 我们可使用ES2015风格的计算属性命名功能来使用一个常量[types.STORE_MOVIE_ID]作为函数名
 [types.STORE_MOVIE_ID]( state, res) {
  state.movieID = res;
 },
}
export default {
 state,
 actions,
 getters,
 mutations
}

下边我们要说的是取数据并且渲染到页面中,或者在页面函数中使用的方法:

1:组建中你需要导入如下:

import { mapGetters } from 'vuex';

在组件的计算属性中,如下:

 computed: {
 ...mapGetters([//...函数名 使用对象展开运算符将此对象混入到外部对象中
  'getContextPathSrc'
  ])
 },

这里的getContextPathSrc函数,在页面中可直接使用,如果在函数中使用,需要this.getContextPathSrc

2:最后在store中写getters函数:

 const getters = {
  // 图片公共 src 的获取 getter函数:state=> state.数据名
  getContextPathSrc: state => state.contextPathSrc,
 }

最后在页面渲染就可以了。。这样就完成了交互。可能有人会留意到上面的getters里的movieID函数有个if判断,最后

 return localStorage.getItem('STORE_MOVIE_ID')

有人会好奇为啥用localStorage……这个我们也不想用,只是如果你的页面如果用户强制刷新一下的话,会有个很奇怪的事发生,就是数据全部取不到,后来是没办法才加的。

最后,希望这些讲解,对于初学者来说有帮助……别被vuex的官网整的云里雾里(ps:我初学时也云里雾里整不明白偷笑)。好了,下班啦,更多的内容,会慢慢跟大家分享。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# vue2  # vuex  # axios  # 详解Vue 2.0封装axios笔记  # vue 里面使用axios 和封装的示例代码  # 浅谈在Vue-cli里基于axios封装复用请求  # vue axios 二次封装的示例代码  # vue 2.x 中axios 封装的get 和post方法  # 详解给Vue2路由导航钩子和axios拦截器做个封装  # Vue二次封装axios为插件使用详解  # Vue.js实战之使用Vuex + axios发送请求详解  # vue+vuex+axios+echarts画一个动态更新的中国地图的方法  # vue2.0学习之axios的封装与vuex介绍  # 是在  # 有个  # 人会  # 的是  # 雾里  # 云里  # 也不  # 好了  # 第一个  # 多个  # 可以用  # 下划线  # 不明白  # 没办法  # 并将  # 能有  # 然后再  # 将此  # 很奇怪  # 可直接 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】  如何在Windows虚拟主机上快速搭建网站?  Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】  Laravel如何配置任务调度?(Cron Job示例)  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤  如何在IIS中配置站点IP、端口及主机头?  Laravel中的Facade(门面)到底是什么原理  无锡营销型网站制作公司,无锡网选车牌流程?  Laravel怎么生成二维码图片_Laravel集成Simple-QrCode扩展包与参数设置【实战】  Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】  如何在宝塔面板创建新站点?  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  Laravel集合Collection怎么用_Laravel集合常用函数详解  如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环  如何在IIS中新建站点并解决端口绑定冲突?  Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全  Laravel如何实现用户注册和登录?(Auth脚手架指南)  laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法  Python文件操作最佳实践_稳定性说明【指导】  Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程  如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体  微信h5制作网站有哪些,免费微信H5页面制作工具?  Laravel N+1查询问题如何解决_Eloquent预加载(Eager Loading)优化数据库查询  如何快速查询域名建站关键信息?  Laravel Asset编译怎么配置_Laravel Vite前端构建工具使用  如何在建站宝盒中设置产品搜索功能?  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  html文件怎么打开证书错误_https协议的html打开提示不安全【指南】  Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  Laravel Sail是什么_基于Docker的Laravel本地开发环境Sail入门  laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法  微信小程序 input输入框控件详解及实例(多种示例)  php 三元运算符实例详细介绍  如何生成腾讯云建站专用兑换码?  网站制作价目表怎么做,珍爱网婚介费用多少?  如何用AWS免费套餐快速搭建高效网站?  如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】  如何在建站之星绑定自定义域名?  微信小程序 require机制详解及实例代码  Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】  Laravel怎么做缓存_Laravel Cache系统提升应用速度的策略与技巧  如何挑选高效建站主机与优质域名?  网页设计与网站制作内容,怎样注册网站?  网易LOFTER官网链接 老福特网页版登录地址  如何快速生成可下载的建站源码工具?  JavaScript如何实现类型判断_typeof和instanceof有什么区别  nodejs redis 发布订阅机制封装实现方法及实例代码  iOS UIView常见属性方法小结