微信小程序 API promisify 及后端接口统一管理

微信小程序 API promisify 及后端接口统一管理微信小程序几乎所有的 API 都是采用回调的形式,很容易陷入“回调地狱”,完全享受不到“现代化”的异步编程 Promise、async/await 所带来的优势。 我们可以对微信小程序的 API Promise 化。 wx.request 是微信小程序最常用的 API 之一,请…

API promisify

微信小程序几乎所有的 API 都是采用回调的形式,很容易陷入“回调地狱”,完全享受不到“现代化”的异步编程 Promise、async/await 所带来的优势。

我们可以对微信小程序的 API Promise 化。

// 封装
export const getImageInfo = (src) => {
  return new Promise((success, fail) => wx.getImageInfo({ src, success, fail }))
}

// 使用
const getBg = getImageInfo(bgUrl)
const getAvatar = getImageInfo(avatarUrl)
Promise.all([getBg, getAvatar]).then(([bg, avatar]) => {
  // ...
})

进一步的,我们可以将一些常用的 API 进行封装:

// utils/promisify.js

/** * 获取图片信息,网络图片需先配置 download 域名才能生效。 * @param {String} src */
export const getImageInfo = (src) => {
  return new Promise((success, fail) => wx.getImageInfo({ src, success, fail }))
}

/** * 保存图片到系统相册 * @param {Object} options */
export const saveImageToPhotosAlbum = (options) => {
  return new Promise((success, fail) => wx.saveImageToPhotosAlbum({ ...options, success, fail }))
}

// ...

miniprogram-api-promise

在生产中,推荐直接使用 npm 包 miniprogram-api-promise,其原理也是使用 Promise 对 API 进行了一次封装:

源码见 node_modules/miniprogram-api-promise/src/promise.js

npm install --save miniprogram-api-promise
import { promisifyAll, promisify } from 'miniprogram-api-promise';

// promisify all wx's api
const wxp = {}
promisifyAll(wx, wxp)
console.log(wxp.getSystemInfoSync())
wxp.getSystemInfo().then(console.log)
wxp.showModal().then(wxp.openSetting())

// compatible usage
wxp.getSystemInfo({success(res) {console.log(res)}})

// promisify single api
promisify(wx.getSystemInfo)().then(console.log)

wx.request 封装

wx.request 是微信小程序最常用的 API 之一,请求的参数较多,请求结束后的操作又是通过回调函数来完成的,多有不便。

下面对该 API 进行封装,使其支持 Promise:

// utils/request.js

/** * promisify wx.request * @param {String} baseURL 域名 * @param {String} url 请求路径 * @param {Object} data 请求参数 * @param {String} method 请求方法 */
class Request {
  constructor(params) {
    this.withBaseURL = params.withBaseURL
    this.baseURL = params.baseURL
  }

  get(url, data) {
    return this.request('GET', url, data)
  }

  post(url, data) {
    return this.request('POST', url, data)
  }

  request(method, url, data) {
    return new Promise((resolve, reject) => {
      wx.request({
        method,
        data,
        url: this.withBaseURL ? this.baseURL + url : url,
        header: getApp().globalData.getHeader(),
        success: (res) => resolve(res),
        fail: (err) => reject(err),
      })
    })
  }
}

export default new Request({
  withBaseURL: true,
  baseURL: getApp().globalData.host,
})

后端接口统一管理

为了便于管理,我们往往会将项目中使用到的 HTTP 请求放到一起进行维护:

// apis/user.js
import request from '../utils/request'

export const addUser = (data) => request.post('/user/add', data)
export const getUserList = (data) => request.get('/user/list', data)
export const getUserInfo = (data) => request.get('/user/info', data)
// apis/product.js
import request from '../utils/request'

export const addProduct = (data) => request.post('/product/add', data)
export const getProductList = (data) => request.get('/product/list', data)
export const getProductDetail = (data) => request.get('/product/detail', data)

参考链接

  1. RequestTask | 微信开放文档:developers.weixin.qq.com/miniprogram…
  2. API Promise化 | 微信开放文档:developers.weixin.qq.com/miniprogram…

今天的文章微信小程序 API promisify 及后端接口统一管理分享到此就结束了,感谢您的阅读。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/16067.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注