mpvue 开发小程序接口数据统一管理
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 开发小程序接口数据统一管理的更多相关文章
- 使用mpvue开发小程序
前言: 最近接到小程序的开发需求,由于之前也没开发过小程序,心情还是有点激动.先花15分钟看一遍小程序官方文档,再花10分钟看一遍mpvue官方文档,然后拿着原型图和UI图就开干.踩了不少坑,写篇博客 ...
- 使用mpvue开发小程序教程(四)
在上一章节中,我们将vue-cli命令行工具生成的代码骨架中的src目录清理了一遍,然后从头开始配置和编写了一个可以运行的小程序页面,算是正真走上了使用mpvue开发小程序的第一步.今天我们将进一步来 ...
- 使用mpvue开发小程序教程(一)
前段时间,美团开源了mpvue这个项目,使得我们又多了一种用来开发小程序的框架选项.由于mpvue框架是完全基于Vue框架的(重写了其runtime和compiler),因此在用法上面是高度和Vue一 ...
- 使用mpvue开发小程序教程(二)
在上篇文章中,我们介绍了使用mpvue开发小程序所需要的一些开发环境的搭建,并创建了第一个mpvue小程序代码骨架并将其运行起来.在本文中,我们来研究熟悉一下mpvue项目的主要目录和文件结构. 在V ...
- 使用mpvue开发小程序教程(五)
在上一章节中,我们了解了组件的三个基本特性以及组件的基本使用方法.在实际的小程序开发中,我们应该以组件的思维去设计每个小程序的功能页面,对其进行合理的组件拆分,让每个部分都保持功能简洁.条理清楚.各司 ...
- 使用mpvue开发小程序教程(三)
在上一篇文章中,我们熟悉了一下通过vue-cli生成的mpvue工程代码骨架的基本结构,大致了解了每一个部分的代码到底要放到何处.从本文起我们就开始涉及真正的编码部分,学习使用Vue的语法去编写小程序 ...
- 学习笔记:mpvue开发小程序——入门
接下来可能要开发一个小程序,同事推荐使用mpvue,那么我提前熟悉下. 官网地址:http://mpvue.com/ 1.快速上手 http://mpvue.com/mpvue/quickstart/ ...
- 使用mpvue开发小程序教程(六)
在上一章节中,我们列举了在Vue中能用但在mpvue中不能用或需要特别注意的特性,在实际开发前了解一下还是很有必要的,可以避免浪费找错误的时间. 如果你使用过原生的小程序框架,你一定经历过或思考过怎么 ...
- 使用mpvue开发小程序如何定义全局变量
我们创建好mpvue项目之后,找到src/main.js打开在后面添加一行代码 (注意:不能在const app = new Vue(App) 之前添加) Vue.prototype.globalDa ...
随机推荐
- 定制Octopress
在 github pages 上搭建好 octopress 博客之后,博客的基本功能就能使用了.如果想自己定制也是没问题的,octopress 有较详尽的官方文档,原则上有问题求助官方即可:octop ...
- TCL S960T刷机包 乐蛙OS5 稳定版 平滑 优化
ROM简介 乐蛙OS5完美的最终稳定版 Ver14.10.17 温馨提示:一定要明确系统双成一个完整的包画刷入前开发版,否则会造成系统异常,请务必备份手机刷机前的信息和数据,刷机过程中,为了避免因数据 ...
- git命令评测
近日得知git命令在库进行操作,查找git尽管小命令(当然,也不能太小),但他们是一个非常强大的组合,更重要的是,它是非常的效果不同状态的命令是不一样的打.该博文总结git命令.. Git命令 命令小 ...
- delphi 颜色,字体保存到INI文件
颜色转换成整型保存{也可以用ColorToString / stringTOColor}字体用下面的函数转换成字符串,然后保存 unit xFonts; interface uses Classes ...
- 签署 Centennial Program Addendum,使用 Desktop Bridge 将 Win32 应用转制成 UWP
原文 签署 Centennial Program Addendum,使用 Desktop Bridge 将 Win32 应用转制成 UWP 能上架 Windows 应用商店的并不一定必须是 UWP 应 ...
- LeetCode OJ平台Sort Colors讨论主题算法
原题如下面,这意味着无序排列(由0,1,2组成).一号通.组织成若干阵列0-几个1-几个2这样的序列. Given an array with n objects colored red, white ...
- 微信公众号开发系列-Http请求包基类
HttpHelper请求包基类,支持get请求和POS要求.以促进微通道交互界面的开发,为了准备的人机交互界面,背部. 1.HttpHelper帮助基类 [csharp] view plaincopy ...
- hdu 2128 Frog(简单DP)
Frog Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Total Submi ...
- DNS查询工具:host、nslookup、dig
作者:zhanhailiang 日期:2014-11-01 1. host host提供域名到IP地址的双向解析: host默认通过/etc/resolv.conf读取Name Server来解析,除 ...
- git建tag备忘
1.git tag -a v1.1.8_20180613 -m '实时上传位置等功能提交测试' 2. git push origin v1.1.8_20180613