mpvue项目里做API与数据分离统一管理

小程序里请求数据接口使用wx:request,因为考虑项目比较大,最好把wx:request封装起来,统一使用管理

utils.js 配置开发环境和线上环境接口

let util = {};

const ajaxUrl = process.env.NODE_ENV === 'development'
// 测试接口地址
? 'code.net.cn/api'
// 线上接口地址
: 'https://api.code.net.cn'; util.API = ajaxUrl;
util.oauthUrl = ajaxUrl; export default util;

fetch.js 暴露封装请求接口方法

import utils from '../utils/utils'
import store from '../vuex/index' export async function request(obj) { let token = store.state.wechat.token; return new Promise((resolve, reject) => {
// 是否显示loading
if (obj.dontLoading !== true) {
wx.showNavigationBarLoading();
wx.showLoading({
mask: true,
title: '处理中'
});
} wx.request({
url: utils.API + obj.url,
data: obj.data,
header: {
'content-type': 'application/json',
'Accept': 'application/json',
'Authorization': 'Bearer ' + token,
...obj.header
},
method: obj.method, success(res) { // 处理返回信息
handleResult(res); // 处理 new token
handleNewToken(res); if (obj.dontLoading !== true && store.state.showing !== true) {
wx.hideLoading();
wx.hideNavigationBarLoading();
} store.commit('setShowing', false); resolve(res.data.data)
}, fail(e) { reject(e)
} })
})
} // 处理new token
function handleNewToken(res) {
let new_token = res.header['New-Token'];
if (new_token) {
store.commit('setToken', new_token)
}
} // 统一显示toast
function showToast(message) {
wx.showToast({
title: message,
icon: 'none',
duration: 2000
}); store.commit('setShowing', true);
}
/**
* 处理code信息
* @param res
*/
function handleResult(res) { let code = res.data.code;
switch (code) {
case 200:
break;
case 401 :
showToast("身份校验信息失败,请刷新页面重试!");
store.dispatch('getUserToken');
break; case 412 :
showToast('未填写个人信息!');
wx.navigateTo({url: '../bind/main'});
break; case 422 :
let errors = '';
for (var key in res.data.errors) {
res.data.errors[key].forEach((item) => {
errors += item + " "
})
}
errors = errors ? errors : '提交的信息错误,请检查!';
showToast(errors);
break; default:
let msg = res.data.message ? res.data.message : '未知错误,请重试!';
showToast(msg);
}
}

统一在vuex里面做数据请求接口

比如订单接口

import {request} from "../../api/fetch";

const state = {
// 订单列表
orderList: [],
} const mutations = {
setOrderList(state, data) {
state.orderList = data;
}
} const actions = {
/**
* 下订单
* @param commit
* @param params
* @returns {Promise<*>}
*/
async createOrder({commit}, params) {
const res = await request({
method: 'post',
url: '/wechat/order',
data: params,
});
return res;
}, /**
* 获取订单详情
* @param commit
* @param id 订单id
* @returns {Promise<*>}
*/
async getOrderDetail({commit}, id) {
const res = await request({
method: 'get',
url: '/wechat/order/' + id,
data: {}
})
return res;
}, /**
* 获取订单列表
* @param commit
* @returns {Promise<*>}
*/
async getOrderList({commit}) {
const res = await request({
method: 'get',
url: '/wechat/order',
data: {}
})
commit('setOrderList', res);
return res;
}
} export default {
state,
actions,
mutations
}

现在已经接口API与请求数据分开统一处理,在页面仅仅需要调用就可以使用数据了

<script>
import {mapActions, mapState} from 'vuex'; export default { computed: {
...mapState({
orderList: state => state.order.orderList,
}), },
async onShow() { // 调用请求获取订单列表接口
await this.getOrderList();
},
methods: {
...mapActions([
'getOrderList',
]),
}
} </script>

在这稍微说一下个人观点,async/await和Promise异步,我这次项目有同时使用promise和async/await,两个有不同的优缺点,Promise的回调机制async/await好,缺点就是写很多then回调,async/await的写法与同步写起来很相似,写起代码来也整洁,易理解。建议大家在不同的场景下使用它们的各自优缺点。

mpvue 开发小程序接口数据统一管理的更多相关文章

  1. 使用mpvue开发小程序

    前言: 最近接到小程序的开发需求,由于之前也没开发过小程序,心情还是有点激动.先花15分钟看一遍小程序官方文档,再花10分钟看一遍mpvue官方文档,然后拿着原型图和UI图就开干.踩了不少坑,写篇博客 ...

  2. 使用mpvue开发小程序教程(四)

    在上一章节中,我们将vue-cli命令行工具生成的代码骨架中的src目录清理了一遍,然后从头开始配置和编写了一个可以运行的小程序页面,算是正真走上了使用mpvue开发小程序的第一步.今天我们将进一步来 ...

  3. 使用mpvue开发小程序教程(一)

    前段时间,美团开源了mpvue这个项目,使得我们又多了一种用来开发小程序的框架选项.由于mpvue框架是完全基于Vue框架的(重写了其runtime和compiler),因此在用法上面是高度和Vue一 ...

  4. 使用mpvue开发小程序教程(二)

    在上篇文章中,我们介绍了使用mpvue开发小程序所需要的一些开发环境的搭建,并创建了第一个mpvue小程序代码骨架并将其运行起来.在本文中,我们来研究熟悉一下mpvue项目的主要目录和文件结构. 在V ...

  5. 使用mpvue开发小程序教程(五)

    在上一章节中,我们了解了组件的三个基本特性以及组件的基本使用方法.在实际的小程序开发中,我们应该以组件的思维去设计每个小程序的功能页面,对其进行合理的组件拆分,让每个部分都保持功能简洁.条理清楚.各司 ...

  6. 使用mpvue开发小程序教程(三)

    在上一篇文章中,我们熟悉了一下通过vue-cli生成的mpvue工程代码骨架的基本结构,大致了解了每一个部分的代码到底要放到何处.从本文起我们就开始涉及真正的编码部分,学习使用Vue的语法去编写小程序 ...

  7. 学习笔记:mpvue开发小程序——入门

    接下来可能要开发一个小程序,同事推荐使用mpvue,那么我提前熟悉下. 官网地址:http://mpvue.com/ 1.快速上手 http://mpvue.com/mpvue/quickstart/ ...

  8. 使用mpvue开发小程序教程(六)

    在上一章节中,我们列举了在Vue中能用但在mpvue中不能用或需要特别注意的特性,在实际开发前了解一下还是很有必要的,可以避免浪费找错误的时间. 如果你使用过原生的小程序框架,你一定经历过或思考过怎么 ...

  9. 使用mpvue开发小程序如何定义全局变量

    我们创建好mpvue项目之后,找到src/main.js打开在后面添加一行代码 (注意:不能在const app = new Vue(App) 之前添加) Vue.prototype.globalDa ...

随机推荐

  1. win10 uwp 使用 msbuild 命令行编译 UWP 程序

    原文:win10 uwp 使用 msbuild 命令行编译 UWP 程序 版权声明:博客已迁移到 http://lindexi.gitee.io 欢迎访问.如果当前博客图片看不到,请到 http:// ...

  2. javascript 获取上一周的时间

    <script type="text/javascript" language="javascript"> //获取系统时间 var LSTR_nd ...

  3. win7 64位系统下进入debug

    win7 64位无法直接通过命名行输入debug命令的方式进入到debug,好在我们可是使用一个工具DOSbox来进入debug.操作步骤如下:1.下载DOSbox进行安装.下载地址:点击打开链接.如 ...

  4. wpf中xaml的类型转换器与标记扩展

    原文:wpf中xaml的类型转换器与标记扩展 这篇来讲wpf控件属性的类型转换器 类型转换器 类型转换器在asp.net控件中已经有使用过了,由于wpf的界面是可以由xaml组成的,所以标签的便利也需 ...

  5. R 语言学习(二)—— 向量

    1. 入门 将摄氏度转化为华氏度 >> 27*1.8+32 [1] 80.6 [1]:表示数字的向量索引号,在 R 语言中任何一个数字都看作一个向量. 向量化 >> temp ...

  6. 王立平--GC

    Gabage Collection:垃圾回收 是.net中对内存管理的一种功能. 垃圾回收器跟踪并回收托管内存中分配的对象,定期运行垃圾回收以回收分配给没有有效引用的对象的内存. 当使用可用内存不能满 ...

  7. WPF中制作立体效果的文字或LOGO图形(续)

    原文:WPF中制作立体效果的文字或LOGO图形(续) 上篇"WPF中制作立体效果的文字或LOGO图形"(http://blog.csdn.net/johnsuna/archive/ ...

  8. HDU 1598 find the most comfortable road (罗列+Kruskal) 并检查集合

    Problem Description XX星有很多城市,城市之间通过一种奇怪的快速公路SARS(Super Air Roam Structure---超级空中漫游结构)进行交流.每条SARS都对行驶 ...

  9. 深入理解最强桌面地图控件GMAP.NET --- 街景地图(StreetView)

    原文:深入理解最强桌面地图控件GMAP.NET --- 街景地图(StreetView) 很久没有更新博客了,今天无事把GMAP.NET的代码又重新翻了翻,看到了街景地图的例子. 街景地图是谷歌最早提 ...

  10. HDU 5073 Galaxy(Anshan 2014)(数学推导,贪婪)

    Galaxy Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others) Total S ...