• 微信小程序接口封装、原生接口封装、request、promise封装


    相信大家在做微信小程序的时候会有很多地方需要调用接口,就和pc以及手机端一样,多个页面多次调用会有很多状态,那为了节省大家的开发时间就会需要给请求的接口做一些简单封装,便于开发,在这里我用了两个js,一个js封装的是方法名,另外一个是接口名,统一管理

    下面这个是统一的接口方法封装

    const baseURL = "接口名";
    const request = params => {
      const token = wx.getStorageSync("token").token;
      return new Promise((resolve, reject) => {
        wx.showLoading();
        wx.request({
          url: baseURL + params.url,
          data: params.data,
          method: params.method,
          header: {
            'content-type': 'application/x-www-form-urlencoded;charset=utf-8',
            token: token
          },
          success(res) {
            const pages = getCurrentPages();
            // const app = getApp();
            if (res.statusCode === 200) {
              if (res.data.code === 200) {
                resolve(res.data);
              } else if (res.data.code === 401) {
                wx.navigateTo({
                  url: '/pages/login/index',
                })
              } else {
                if (res.data.code == 1104) {
                  wx.clearStorageSync()
                  wx.redirectTo({
                    url: '/pages/login/index',
                  })
                } else {
                  reject(res.data);
                }
              }
            }
          },
          fail(err) {
            reject(err);
          },
          complete() {
            wx.hideLoading();
          }
        });
      });
    };
    const _upload = (filePath, type) => {
      const token = wx.getStorageSync("token").access_token;
      return new Promise((resolve, reject) => {
        wx.showLoading();
        wx.uploadFile({
          url: baseURL + "upload_file", //仅为示例,非真实的接口地址
          filePath,
          name: "file",
          header: {
            authorization: token ? "Bearer " + token : undefined
          },
          formData: {
            type
          },
          success(res) {
            resolve(JSON.parse(res.data));
          },
          fail(err) {
            reject(err);
          },
          complete() {
            wx.hideLoading();
          }
        });
      });
    };
    const _get = (url, data) => {
      return request({
        url,
        data,
        method: "GET"
      });
    };
    const _post = (url, data) => {
      return request({
        url,
        data,
        method: "POST"
      });
    };
    const _put = (url, data) => {
      return request({
        url,
        data,
        method: "PUT"
      });
    };
    const _delete = (url, data) => {
      return request({
        url,
        data,
        method: "DELETE"
      });
    };
    module.exports = {
      baseURL,
      _get,
      _post,
      _put,
      _delete,
      _upload
    };

    下面这个是统一的接口管理

    import { _get, _post, _put, _delete, _upload } from "./request";
    
    // 图片上传
    const getUploadImg = data => {
      return _post("接口名", data);
    };
    module.exports = {
      getUploadImg
    };

    封装的比较简单粗暴,不过通俗易懂
    使用的时候直接在页面引入就可以

  • 相关阅读:
    范仁义js课程---54、匿名函数在框架中的应用
    js中的匿名函数
    【转】使用VisualSVN Server搭建SVN服务器
    浅析Java中CountDownLatch用法
    【转】Android平台下利用zxing实现二维码开发
    【转】Android应用开发性能优化完全分析
    Android自由行之走进zxing,轻松实现二维码扫描
    【转】Java Thread.join()详解
    【转】Spring websocket 使用
    spring4使用websocket
  • 原文地址:https://www.cnblogs.com/yequxue/p/13084654.html
Copyright © 2020-2023  润新知