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. ListView与GridView优化

    前言 ListView是Android中最常用的控件,通过适配器来进行数据适配然后显示出来,而其性能是个很值得研究的话题.本文与你一起探讨Google I/O提供的优化Adapter方案,欢迎大家交流 ...

  2. 自定义滚动条样式 -webkit-scrollbar

    demo .page-one-content-area-inner-select-wrap height 200px margin-bottom 30px overflow auto &::- ...

  3. Android子线程中更新UI的4种方法

    方法一:用Handler 1.主线程中定义Handler: Handler mHandler = new Handler() { @Override public void handleMessage ...

  4. ASP.NET Page执行顺序(ASP.NET生命周期)

    此部分说明的生命周期只有部分: ---引用MSDN 阶段 说明 页请求 页请求发生在页生命周期开始之前.用户请求页时,ASP.NET 将确定是否需要分析和编译页(从而开始页的生命周期),或者是否可以在 ...

  5. OpenCV图像的基础叠加

    程序及分析 /* * FileName : blend.cpp * Author : xiahouzuoxin @163.com * Version : v1.0 * Date : Mon 28 Ju ...

  6. ASP.NET Core 配置 EF SQLite 支持 - ASP.NET Core 基础教程 - 简单教程,简单编程

    原文:ASP.NET Core 配置 EF SQLite 支持 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 配置 EF SQLite 支持 上一章节我有提 ...

  7. WPF使用DynamicDataDisplay.dll显示CPU及内存使用曲线

    原文:WPF使用DynamicDataDisplay.dll显示CPU及内存使用曲线 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/wangshub ...

  8. wpf版权限管理

    之前做的权限管理是基于Mvc的Web项目,模型.仓储及业务层次分明,6月中旬开始使用这套之前完成的底层架构开发Wpf版本的权限管理软件(后续将成熟企管系统进行抽象业务加入到该版本中,向企管系统靠近) ...

  9. 关闭Mac OS 的Rootless

    今天在使用mac的时候,需要删除 /usr/bin/下的 自带的php文件.然后提示Operation not permitted 使用sudo 依然不可以,通过google 得到解决方案. 需要关闭 ...

  10. WPF 悬浮键盘

    原文:WPF 悬浮键盘 public class TouchScreenKeyboard : Window { #region Property & Variable & Constr ...