promise封装wx.request()

使用promise封装wx.request()

1、目录结构

在根目录下创建http目录及api.js文件fetch.js以及http.js文件;promise封装wx.request()_第1张图片
在根目录下创建env目录,创建index.js配置并导出多个开发环境
下面展示一些 内联代码片

module.exports={
     
  //开发环境
  Dev:{
     
    "BaseUrl":"https://www.develep.com"
  },
  //测试环境
  Test:{
     
    "BaseUrl":"https://www.test.com"
  },
  //生产环境
  Prod:{
     
    "BaseUrl": "https://api.douban.com"
  }
}

在api.js中统一管理,请求的url地址

module.exports={
     
  "hot":"/v2/movie/in_theaters",
  "top250": "/v2/movie/top250",
  "detail": "v2/movie/subject"
}

在fetch.js中用promise对wx.request()进行封装

//封装wx.request()网络模块
module.exports=(url,method,data)=>{
     
  let p=new Promise((resolve,reject)=>{
     
    wx.request({
     
      url: url,
      method:method,
      data:Object.assign({
     },data),
      header:{
     'Content-Type': 'application/text' },
      success(res){
     
        resolve(res)
      },
      fail(err){
     
        reject(err)
      }
    })
  })
  return p;
}

在http.js,根据当前环境,设置相应的baseUrl, 引入fetch中封装好的promise请求,封装基础的get\post\put\upload等请求方法,设置请求体,带上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:[]
  }
onLoad: function () {
     
    app.http.banner().then((res)=>{
     
                this.setData({
     
                    list: res.data.list
        })    })
}

————————————————
版权声明:本文为CSDN博主「一个小开心呀」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_52753294/article/details/111603461

你可能感兴趣的:(es6)