wx.request完整代码
wx.request({
url: 'url',// 请求地址
header:{// 请求头
'content-type':'application/json'
},
method:'POST',// 请求方法
data:{
// 请求参数
},
success:res=>{
console.log('成功',res);
},
fail:err=>{
console.log('失败回调',err);
},
complete(){
console.log('回调成功与否都会执行')
}
})
如果每个需要网络请求的地方我们都使用官方提供的wx.request请求,大大的增加了代码量。使用Promise方法封装wx.request哪就可以使用Promise的then()方法来获取成功回调catch()获取失败回调,废话不多说,直接上代码。
新建一个api文件夹,在api文件夹下创建一个request.js文件把wx.request用promise方法封装起来
const baseURL = "请求基础路径"
export function request(options){
return new Promise((resolve,reject)=>{
wx.request({
url: baseURL + options.url,
data:options.data || {},
method:options.method || 'get',
success:res=>{
resolve(res)
},
fail:err=>{
reject(err)
}
})
})
}
api文件夹内再创建一个index.js文件,把不同的请求方法都放着统一管理
import {request} from './request'
export function getList(data){
return request({
url:'/upload',
header:{
'content-type':'application/json'
// 如有token的需求可以在此处携带,也可以在request.js定义
},
data:data,
method:'post'
})
}
使用时通过import 导入的方法,把在api文件夹下创建的index.js导入使用
import {getList} from '../../api/index'
getList().then(res=>{console.log('成功回调',res)}).catch(err=>{console.log('失败回调',err)})
这样我们的wx.request就精简很多啦,以后维护起来也跟方便