如何使用Promise封装wx.request()
目录结构
在基础的项目上创建一个http文件夹,在http里面建立3个js文件
在根目录下在创建一个env文件夹,在里面创建index.js文件,可以配置多个环境并导出
module.exports={
//开发环境
Dev:{
"BaseUrl":"https://www.develep.com"
},
//测试环境
Test:{
"BaseUrl":"https://www.test.com"
},
//生产环境
Prod:{
"BaseUrl": "https://api.douban.com"
}
}
在app.js里面配置需要的接口
在fetch.js里面使用Promise对wx.requset进行封装
module.exports=(url,data,module)=>{
let p = new Promise((resolve,reject)=>{
wx.request({
url: url,
data:data,
module:module,
success(res){
resolve(res)
},
fail(err){
reject(err)
}
})
})
exports=(url,data,module)=>{
return new Promise((resolve,reject)=>{
wx.request({
url: url,
data:data,
module:module,
success(res){
resolve(res)
},
fail(err){
reject(err)
}
})
})
}
return p
}
在http.js里面,根据当前环境,设置相应的baseUrl,引入fatch中封装好的promise请求,封装基础的get,post,put,等请求方法,带上token和异常处理等;设置对应的方法并导出
const evn=require('../env/index.js')
const api=require('./api')
const fetch = require('./fetch')
//确定开发环境
let baseUrl=evn.devBaseUrl;
//如果接口需要token鉴权,获取token
let token=wx.getStorageSync('token');
//轮播请求函数
function banner(){
return fetch(baseUrl+api.banner,'get',{})
}
//list列表函数
//分类接口函数
module.exports={
banner
}
在全局app.js中导入http,注册根组件
const http=require('./http/http.js')
// App.config=config[env];
App({
http, // http.fetch
})
在具体对应的父页面,并使用
//获取应用实例
const app = getApp();
Page({
data: {
list:[]
}
//生命周期函数 相当于vue中的create
onLoad: function () {
app.http.banner().then((res)=>{
this.setData({
list: res.data.list
}) })
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。