原生小程序如何封装请求,优雅地调用接口?

 3432

微信小程序如何封装原生请求?如何调用接口?下面本篇文章给大家介绍一下原生微信小程序封装请求,并优雅调用接口的方法,希望对大家有所帮助!


原生小程序如何封装请求,优雅地调用接口?

本文属于代码片段,对于原生微信小程序请求的封装。有个人书写习惯,仅供参考。

基于小程序原生request封装Promise风格的请求

避免多级回调(回调地狱)

对于网络请求错误统一处理分发


目录结构

  1. .
  2. ├── api
  3. │   ├── config.js // 相关请求的配置项,请求api等
  4. │   ├── env.js // 环境配置
  5. │   ├── request.js  // 封装主函数
  6. │   ├── statusCode.js // 状态码
  7. └── ...


相关代码

配置文件

env.js

  1. // env.js
  2. module.exports = {
  3.   ENV: 'production',
  4.   // ENV: 'test'
  5. }

statusCode.js

  1. // statusCode.js
  2. // 配置一些常见的请求状态码
  3. module.exports = {
  4.   SUCCESS: 200,
  5.   EXPIRE: 403
  6. }

config.js

  1. // config.js
  2. const { ENV } = require('./env')
  3. let BASEURL
  4.  
  5. switch (ENV) {
  6.   case 'production':
  7.     BASEURL = ''
  8.     break
  9.   case 'test':
  10.     BASEURL = ''
  11.     break
  12.   default:
  13.     BASEURL = ''
  14.     break
  15. }
  16. module.exports = {
  17.   BASEURL,// 项目接口地址,支持多域名
  18. }


主函数

注意 64~68行是对token过期的处理,在调用登录的时候, 检查app.globalData中是否存在token,存在则不发起登录请求,token过期清空token,那么下一次请求的时候就会 重新发起登录请求从而会重新获取到新的token

  1. // 引入状态码statusCode
  2. const statusCode = require('./statusCode')
  3. // 定义请求路径, BASEURL: 普通请求API; CBASEURL: 中台API,不使用中台可不引入CBASEURL
  4. const { BASEURL } = require('./config')
  5. // 定义默认参数
  6. const defaultOptions = {
  7.   data: {},
  8.   ignoreToken: false,
  9.   form: false,
  10. }
  11. /**
  12.  * 发送请求
  13.  * @params
  14.  * method: <String> 请求方式: POST/GET
  15.  * url: <String> 请求路径
  16.  * data: <Object> 请求参数
  17.  * ignoreToken: <Boolean> 是否忽略token验证
  18.  * form: <Boolean> 是否使用formData请求
  19.  */
  20. function request (options) {
  21.   let _options = Object.assign(defaultOptions, options)
  22.   let { method, url, data, ignoreToken, form } = _options
  23.   const app = getApp()
  24.   // 设置请求头
  25.   let header = {}
  26.   if (form) {
  27.     header = {
  28.       'content-type': 'application/x-www-form-urlencoded'
  29.     }
  30.   } else {
  31.     header = {
  32.       'content-type': 'application/json' //自定义请求头信息
  33.     }
  34.   }
  35.   if (!ignoreToken) {
  36.     // 从全局变量中获取token
  37.     let token = app.globalData.token
  38.     header.Authorization = `Bearer ${token}`
  39.   }
  40.   return new Promise((resolve, reject) => {
  41.     wx.request({
  42.       url: BASEURL + url,
  43.       data,
  44.       header,
  45.       method,
  46.       success: (res) => {
  47.         let { statusCode: code } = res
  48.         if (code === statusCode.SUCCESS) {
  49.           if (res.data.code !== 0) {
  50.             // 统一处理请求错误
  51.             showToast(res.data.errorMsg)
  52.             reject(res.data)
  53.             return
  54.           }
  55.           resolve(res.data)
  56.         } else if (code === statusCode.EXPIRE) {
  57.           app.globalData.token = ''
  58.           showToast(`登录过期, 请重新刷新页面`)
  59.           reject(res.data)
  60.         } else {
  61.           showToast(`请求错误${url}, CODE: ${code}`)
  62.           reject(res.data)
  63.         }
  64.       },
  65.       fail: (err) => {
  66.         console.log('%c err', 'color: red;font-weight: bold', err)
  67.         showToast(err.errMsg)
  68.         reject(err)
  69.       }
  70.     })
  71.   })
  72. }
  73.  
  74. // 封装toast函数
  75. function showToast (title, icon='none', duration=2500, mask=false) {
  76.   wx.showToast({
  77.     title: title || '',
  78.     icon,
  79.     duration,
  80.     mask
  81.   });
  82. }
  83.  
  84. function get (options) {
  85.   return request({
  86.     method: 'GET',
  87.     ...options
  88.   })
  89. }
  90.  
  91. function post (options) {
  92.   // url, data = {}, ignoreToken, form
  93.   return request({
  94.     method: 'POST',
  95.     ...options
  96.   })
  97. }
  98.  
  99. module.exports = {
  100.   request, get, post
  101. }


使用方法

新建文件

新建api文件(此处以订单接口为例), 新建api/index.js(接口分发统一处理,防止接口写到同一个文件下过于冗长)

目录结构如下:

  1. .
  2. ├── api
  3. │   ├── config.js // 相关请求的配置项,请求api等
  4. │   ├── index.js  // 统一处理入口
  5. │   ├── order.js  // 订单接口
  6. │   ├── request.js  // 封装主函数
  7. │   ├── statusCode.js // 状态码
  8. └── ...

引入request

  1. // order.js
  2. const request = require('./request')
  3.  
  4. module.exports = {
  5.   // data可以传入 url, data, ignoreToken, form, cToken
  6.   apiName (data) {
  7.     let url = 'apiUrl'
  8.     return request.post({ url, data })
  9.   }
  10. }

统一分发接口

  1. const orderApi = require("./order")
  2.  
  3. module.exports = {
  4.   orderApi
  5. }

页面引用

  1. const { orderApi } = require('dir/path/api/index')
  2. ...
  3. 1. `Promise.then()`链式调用
  4. func () {
  5.   orderApi.apiName(params).then(res => {
  6.     // do Something
  7.   }).catch(err => {
  8.     // do Something
  9.   })
  10. }
  11.  
  12. 2. `async/await` 调用
  13. async func () {
  14.   try {
  15.     let res = await orderApi.apiName(params)
  16.     // do Something
  17.   } catch (err) {
  18.     // do Something
  19.   }
  20. }

options取值


参数说明数据类型默认值
url接口名String''
data请求体Object{}
ignoreToken请求是否携带tokenBooleanfalse
form是否是表单请求Booleanfalse


本文网址:https://www.zztuku.com/index.php/detail-10280.html
站长图库 - 原生小程序如何封装请求,优雅地调用接口?
申明:本文转载于《掘金社区》,如有侵犯,请 联系我们 删除。

评论(0)条

您还没有登录,请 登录 后发表评论!

提示:请勿发布广告垃圾评论,否则封号处理!!

    编辑推荐