微信小程序——初始化(二)全局封装网络请求

网络请求

1.第一步:新建promisic文件

// utils/promisic.js
export default (func) => {
  return function (params = {}) {
    return new Promise((resolve, reject) => {
      const args = Object.assign(params, {
        success: res => resolve(res),
        fail: err => reject(err),
        complete() {
        }
      });
      func(args)
    })
  }
}

2.第二步:新建request.js文件

// utils/request.js
import promisic from "./promisic";

const baseUrl = 'https://aaa-cc.shshsh.cn/';

const request =async(url,data,method,openid = true) =>{
  const options = {
    url:baseUrl + url,
    header:{
      'content-type' : 'application/x-www-form-urlencoded',
      'openid':opneid?await Request.getOpenId() : null
    },
    method,
    dataType:'json',
    responseType:'text',
    data
  };
  return promisic(wx.request)(options)
  .then((res)=>{
    const {statusCode,data} = res;
    if(statusCode === 200){
      return data
    }
    if(statusCode ===401){
      wx.reLaunch({
        // 账号异常
        url: '/pages/errorPage/index',
      })
    }
    wx.showToast({
      title: data,
      icon:'none',
      duration:2000
    })
    throw new Error(data)
  })
};
/**
 * 网络请求工具类
*/
export default class Request{
  static async get(url,data = {}){
    return await request(url,data,'GET')
  }
  static async post(url,data = {},openid){
    return await request(url,data,'POST')
  }
  static async getOpenId(){
    // 全局挂载标量
    const app = getApp();
    // 获取code
    const res = await promisic(wx.login)();
    // 获取openid
    app.globalData.openid = await request(url,{
      code:res.code
    },'GET',false)
    return app.globalData.openid
  }
}

留档,以后需要时可以直接修改使用,希望也同样适合你哦~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值