首先, 概括下 vuex基本使用流程为: 在action中分发异步请求, 在异步回调中提交mutation,在mutation中修改state, 使用getters对state的值进行计算封装.
为了能够很好的隔离页面view视图与数据的请求, 同时在使用vuex的action分发异步请求后,能够接收回调,进行了以下封装:
一. http的封装
http模块包含3个文件, config.js , http.js , api.js
config.js 封装网关域名,及所有接口的方法名
data:image/s3,"s3://crabby-images/fd983/fd9832aa36af106fd9c3809dab595702f93cf9f7" alt=""
http.js 封装axios基本的get, post请求
data:image/s3,"s3://crabby-images/1a9d9/1a9d9418de67430bb4f0002670f0404e64888ba9" alt=""
api.js 封装接口名及对应的传输字段,回调响应数据
data:image/s3,"s3://crabby-images/3b110/3b110dbb6256fdd5122fea888e6aaa2bfcfd82f5" alt=""
二. vuex模块的封装
vuex通过action异步请求,为了回调执行状态,需在action中返回promise,针对该异步请求的封装, 分为2种情况:
1. view层需要渲染的数据,例如:加载用户基本信息,加载商品列表,订单列表
异步请求后,需要提交mutation,修改state,使用getters计算
2. 执行某个功能动作,例如点赞,添加,删除
异步请求后,不需要提交mutation,不需要使用state中的数据
下图的获取用户基本信息属于情况1, 执行点赞动作属于情况2
data:image/s3,"s3://crabby-images/e1aaf/e1aaf33033750d89ec5e74ede37be9576aa93461" alt=""
为了处理以上两种情况,做了以下封装 (假设:code=1,请求成功, code=0, 请求失败)
data:image/s3,"s3://crabby-images/b793b/b793b026ea1fbc958660946b09b80709f8037b0b" alt=""
data:image/s3,"s3://crabby-images/d3e95/d3e954ff1560535d388d107186f875c3ed918b9e" alt=""
在页面调用如下:
data:image/s3,"s3://crabby-images/212e4/212e4ef3e15c50ecb95aab14ef46b0f725429097" alt=""