小程序如何自主实现拦截器的示例代码


Posted in Javascript onNovember 04, 2019

在一些框架中发现会提供一个很实用的功能:拦截器(interceptor)。例如要实现这个需求:小程序每次获取到定位后都存到 globalData 里:

wx.getLocation({
 // ..
 success(res) {
  getApp().globalData.location = res
  // ...
 }
})

如果每一处使用 wx.getLocation 的地方都这么写也没啥大问题,但总显得不够“智能”,一方面是多了重复代码,另一方面如果需求变动,获取到定位后存到别的地方,那要改很多次。

优雅的拦截器

有了拦截器,可以更优雅的实现它:

intercept('getLocation', {
 success(res) {
  getApp().globalData.location = res
 }
})

只要在一处定义如上的拦截器,其他地方直接用 wx.getLocation 即可。那么,如何实现上面的方式呢?

实现 intercept 方法

// utils/intercept.js
// 存储拦截器定义
var interceptors = {}
function intercept(key, config) {
 intercept[key] = config
}
export {
 intercept,
 interceptors
}

很简单,暴露出 intercept 方法,定义一个存储器也一并暴露出去。

代理 wx

要实现使用 wx.getLocation 自动应用拦截器,就必须基于原有方法重新定义它。

import { interceptors } from './intercept'

// 备份原有微信方法
var wxBackup = {}
[
 'getLocation'
 // 还可以有很多其他方法 ...
].forEach((key) => {
 wxBackup[key] = wx[key]
 wx[key] = (config) => {
  if (interceptors[key]) {
   // 备份业务代码传入的回调方法
   var backup = {}
   var interceptor = interceptors[key]
   [
    'success',
    'fail',
    'complete'
   ].forEach((k) => {
    backup[k] = config[k]
    config[k] = (res) => {
     interceptor[k](res)
     backup[k](res)
    }
   })
  }
  wxBackup[key](config)
 }
})

当然,上述代码用数组列出了所有可能被定义拦截器的微信函数,也可以使用 Object.keys(wx) 通用处理。

更多使用场景

上面的场景比较简单,拦截器的应用还有更多场景。比如每次请求传参带上公参经纬度,接口返回的数据都会约定包裹在 object 中,请求回来需要取一遍。数据异常时还要针对错误码做特定处理,就可以很方便的用拦截器处理:

intercept('request', {
 data(data) {
  var location = getApp().globalData.location
  data.location = location.latitude + ',' + location.longitude
  return data
 },
 success(res) {
  if (res.code == 200) {
   return res.object
  } else {
   if (res.code == 'xxx') {
    // 登录失效,重新登录
    // ....
   }
  }
 }
})

注意,拦截器函数里多了返回值,具体实现方法就不多写,基于上述实现完善代码即可。

总结

细心的读者可能发现,我们代理或者改造了很多微信提供的方法,有些开发者可能不喜欢这样,希望保持原有代码的纯洁性。这要看团队喜好吧,基于此考虑,主要是不想定义太多新的方法或 api,尽量以大家最为熟悉的方式书写代码。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
实现变速回到顶部的JavaScript代码
May 09 Javascript
js switch case default 的用法示例介绍
Oct 23 Javascript
原生js与jQuery实现简单的tab切换特效对比
Jul 30 Javascript
浅谈JavaScript的内置对象和浏览器对象
Jun 03 Javascript
整理关于Bootstrap模态弹出框的慕课笔记
Mar 29 Javascript
利用node.js+mongodb如何搭建一个简单登录注册的功能详解
Jul 30 Javascript
微信小程序实现导航栏选项卡效果
Jun 19 Javascript
微信小程序中this.data与this.setData的区别详解
Sep 17 Javascript
浅析JS中什么是自定义react数据验证组件
Oct 19 Javascript
原生JS使用Canvas实现拖拽式绘图功能
Jun 05 Javascript
js定义类的方法示例【ES5与ES6】
Jul 30 Javascript
微信小程序点击顶部导航栏切换样式代码实例
Nov 12 Javascript
uni-app微信小程序登录并使用vuex存储登录状态的思路详解
Nov 04 #Javascript
JavaScript判断浏览器版本的方法
Nov 03 #Javascript
JavaScript算法学习之冒泡排序和选择排序
Nov 02 #Javascript
如何正确理解vue中的key详解
Nov 02 #Javascript
Javascript 关于基本类型和引用类型的个人理解
Nov 01 #Javascript
javascript 关于赋值、浅拷贝、深拷贝的个人理解
Nov 01 #Javascript
vue iview的菜单组件Mune 点击不高亮的解决方案
Nov 01 #Javascript
You might like
php导出word格式数据的代码实例
2013/11/25 PHP
WebQQ最新登陆协议的用法
2014/12/22 PHP
php使用MySQL保存session会话的方法
2015/06/18 PHP
PHP多态代码实例
2015/06/26 PHP
分享ThinkPHP3.2中关联查询解决思路
2015/09/20 PHP
php使用goto实现自动重启swoole、reactphp、workerman服务的代码
2020/04/13 PHP
js模拟实现Array的sort方法
2007/12/11 Javascript
Exjs 入门篇
2010/04/07 Javascript
基于JQuery的Select选择框的华丽变身
2011/08/23 Javascript
在Iframe中获取父窗口中表单的值(示例代码)
2013/11/22 Javascript
网页下载文件期间如何防止用户对网页进行其他操作
2014/06/27 Javascript
node.js中格式化数字增加千位符的几种方法
2015/07/03 Javascript
JavaScript知识点总结(六)之JavaScript判断变量数据类型
2016/05/31 Javascript
AngularJS使用ng-repeat指令实现下拉框
2016/08/23 Javascript
Angularjs使用ng-repeat中$even和$odd属性的注意事项
2016/12/31 Javascript
JavaScript 上传文件(psd,压缩包等),图片,视频的实现方法
2017/06/19 Javascript
Vue.js获取被选择的option的value和text值方法
2018/08/24 Javascript
浅析Proxy可以优化vue的数据监听机制问题及实现思路
2018/11/29 Javascript
一文快速了解JQuery中的AJAX
2019/05/31 jQuery
深入解析Python编程中super关键字的用法
2016/06/24 Python
Python简单生成8位随机密码的方法
2017/05/24 Python
浅谈python 线程池threadpool之实现
2017/11/17 Python
python特性语法之遍历、公共方法、引用
2018/08/08 Python
python logging模块书写日志以及日志分割详解
2019/07/22 Python
python运用pygame库实现双人弹球小游戏
2019/11/25 Python
tensorflow-gpu安装的常见问题及解决方案
2020/01/20 Python
解决Python logging模块无法正常输出日志的问题
2020/02/21 Python
Python selenium模拟手动操作实现无人值守刷积分功能
2020/05/13 Python
Python自动化操作实现图例绘制
2020/07/09 Python
H5页面适配iPhoneX(就是那么简单)
2019/12/02 HTML / CSS
Rhone官方网站:男士运动服装、健身服装和高级运动服
2019/05/01 全球购物
英国首屈一指的票务公司:See Tickets
2019/05/11 全球购物
公司会计岗位职责
2014/02/13 职场文书
情人节活动策划方案
2014/02/27 职场文书
企业爱岗敬业演讲稿
2014/09/04 职场文书
世界文化遗产导游词
2019/08/07 职场文书