zoukankan      html  css  js  c++  java
  • 微信小程序接口封装、原生接口封装、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
    };

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

  • 相关阅读:
    从Linux内核中获取真随机数【转】
    linux下pthread_cancel无法取消线程的原因【转】
    LINUX-内核-中断分析-中断向量表(3)-arm【转】
    ARM中断向量表与响应流程【转】
    小任务与工作队列的区别【转】
    GNU Readline 库及编程简介【转】
    Linux 内核同步之自旋锁与信号量的异同【转】
    Professional Linux Kernel Architecture 笔记 —— 中断处理(Part 2)【转】
    Linux中断(interrupt)子系统之二:arch相关的硬件封装层【转】
    浅谈C语言中的强符号、弱符号、强引用和弱引用【转】
  • 原文地址:https://www.cnblogs.com/yequxue/p/13084654.html
Copyright © 2011-2022 走看看