小程序:使用promise封装wx.request()

使用promise封装wx.request()

1.目录结构
在根目录下创建http目录及api.js文件fetch.js以及http.js文件;

在这里插入图片描述

在根目录下创建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={
    swiper:"/home/swiperdata",
    tab:"/home/catitems",
    floor:"/home/floordata",
    list:"/categories",
    goodlist:"/goods/search",
    goods_detail:"/goods/detail"
}
在fetch.js中用promise对wx.request()进行封装
module.exports=(url,data,methods)=>{
    let demand=new Promise((resolve,reject)=>{
        wx.request({
          url: url,
          data:data,
          method:methods,
          success(res){
              resolve(res)
          },
          fail(err){
              reject(err)
          }
        })
    })
    return demand
}
在http.js,根据当前环境,设置相应的baseUrl, 引入fetch中封装好的promise请求,封装基础的get\post\put\upload等请求方法,设置请求体,带上token和异常处理等;设置对应的方法并导出;
let demand =require("./demand")
let api =require("./api")
let beseUrl="https://api-hmugo-web.itheima.net/api/public/v1"
// 轮播
function swiper(){
    return demand(beseUrl+api.swiper,{},"get")
}
// 分类
function tab(){
    return demand(beseUrl+api.tab,{},"get")
}
// 楼层
function floor(){
    return demand(beseUrl+api.floor,{},"get")
}
// 分类
function list(){
    return demand(beseUrl+api.list,{},"get")
}
// 点击详情
function goodlist(id){
    return demand(beseUrl+api.goodlist,{cid:id},"get")
}
function goods_detail(id){
    return demand(beseUrl+api.goods_detail,{goods_id:id},"get")
}
module.exports={
    swiper,
    tab,
    floor,
    list,
    goodlist,
    goods_detail
}
在全局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
        })    })
}
使用promise封装wx.request()

在根目录下创建http目录及api.js文件fetch.js以及http.js文件;
1、首先在env目录下创建index.js,里面配置开发环境并将其导出(配置不同的开发环境:开发环境、测试环境、生产环境)
	三个环境也可以说是系统开发的三个阶段:开发->测试->上线,其中生产环境也就是通常说的真实环境。

	- 开发环境:开发环境是程序猿们专门用于开发的服务器,配置可以比较随意,为了开发调试方便,一般打开全部错误报告。
	- 测试环境:一般是克隆一份生产环境的配置,一个程序在测试环境工作不正常,那么肯定不能把它发布到生产机上。
	- 生产环境:是值正式提供对外服务的,一般会关掉错误报告,打开错误日志。

	三个环境也可以说是系统开发的三个阶段:开发->测试->上线,其中生产环境也就是通常说的真实环境。

2、在api.js中统一管理,请求的url地址(定义请求路径并抛出对象)

3、在fetch.js中用promise对wx.request()进行封装(封装wx.request()网络模块 、抛出一个函数 这个函数会返回一个promise对象)

4、在http.js,根据当前环境,设置相应的baseUrl, 引入fetch中封装好的promise请求,封装基础的get\post\put\upload等请求方法,设置请求体,带上token和异常处理等;

设置对应的方法并导出;(入口函数,引入环境变量,路径和方法在此处统一调用;确定当前环境、请求的函数,将封装好的方法抛出)

5、在全局app.js中(用require导入)导入http,注册到根组件,在具体页面导入(用getApp导入全局的app组件),并使用;

const app = getApp();

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值