小程序 Promise

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了小程序 Promise相关的知识,希望对你有一定的参考价值。

参考技术A 微信小程序目前已经支持了包括 Symbol、Set、Map、Promise在内的大部分内置对象以及相关的 ES6 方法。小程序中已经原生支持 Promise,不需要引入第三方类库。

以下四个都是集合方法,代表将多个 Promise 实例集合成一个新的 Promise 总实例,并施加一种执行控制策略。这四个方法接受的参数都是一个数组,数组的元素都是 Promise 实例。

微信小程序封装Promise

我们为什么要分装Promise:因为减少步骤,

   wx.request({         //请求借口
          url: url,  //借口地址
          data:data,    //请求的参数
          method:method,  // 什么请求 git 或者 post
          success:((res)=>{    //success 正确的返回值
            resolove (res)
          }),
          fail:((res)=>{     //fail 错误的返回值
            reject (res)
          })
        })

我们每次都得这样写比较麻烦,所以我们封装一个方法,

第一步、创建一个文件夹跟三个js文件
创建三个js文件
第二步 pe.js写 封装方法

module.exports=(url,data,method)=>{       //导出  
var p=new Promise((resolove,reject)=>{   // new 一个promise里面写方法
        wx.request({
          url: url,
          data:data,
          method:method,
          success:((res)=>{
            resolove (res)
          }),
          fail:((res)=>{
            reject (res)
          })
        })
})
return p         //封装完以后返回值 promise
}

2.ho.js 里面写 借口地址的集合

module.exports={
  sw:'/home/multidata'
}

3.在pl.js 中 先导入封装的方法跟地址的集合在在写一个基地址,基地址+地址的集合 导出一下

var a=require('./ho')
var b=require("./pe")  //导入二个js文件
var baseUrl="http://123.207.32.32:8000/api/h8"  //基地址
function banner(){                                 
return  b(baseUrl+a.sw,{},'get')           // 返回值基地址+借口集合
,git请求
}

module.exports={
   banner        
}

四、在全局的app.js里面导入基地址+借口合集的js文件

然后在配置

  globalData: {
    userInfo: null
  },
  http:http

五、然后在那个文件里面使用就导入全局的配置文件使用即可

var app=new getApp() 导入去全局文件
在  /**
   * 生命周期函数--监听页面加载
   */ 里面使用
       var ths =this

    app.http.banner().then((res)=>{   //封装后的借口请求
        console.log(res);
        var f=res.data.data.banner.list
        this.setData({  //修改数据
          arr:f
        })
      })
      console.log(app.http);

或者可以看:https://blog.csdn.net/weixin_43638968/article/details/109570018?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522162038434816780357280471%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fall.%2522%257D&request_id=162038434816780357280471&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2allfirst_rank_v2~rank_v29-2-109570018.first_rank_v2_pc_rank_v29&utm_term=%E7%94%B0%E5%85%B4%E5%B0%81%E8%A3%85

或者

https://blog.csdn.net/weixin_43638968/article/details/109570018?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522162038434816780357280471%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fall.%2522%257D&request_id=162038434816780357280471&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2allfirst_rank_v2~rank_v29-2-109570018.first_rank_v2_pc_rank_v29&utm_term=%E7%94%B0%E5%85%B4%E5%B0%81%E8%A3%85

总结步骤:1.在js中用promise对wx.request()进行封装
2.在js中统一管理,请求的url地址
3.在http.js,根据当前环境,设置相应的baseUrl, 引入fetch中封装好的promise请求,封装基础的get\\post\\put\\upload等请求方法,设置请求体,带上token和异常处理等;
设置对应的方法并导出;
4.在全局app.js中导入http,注册到根组件
5.在组件中导入并且使用

以上是关于小程序 Promise的主要内容,如果未能解决你的问题,请参考以下文章

小程序 Promise

微信小程序 es6 promise

promise化微信小程序api

小程序网络请求Promise化

小程序网络请求Promise化

小程序api的promise封装