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


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 相关文章推荐
不间断滚动JS打包类,基本可以实现所有的滚动效果,太强了
Dec 08 Javascript
firefox事件处理之自动查找event的函数(用于onclick=foo())
Aug 05 Javascript
jquery.cvtooltip.js 基于jquery的气泡提示插件
Nov 19 Javascript
jquery特效 幻灯片效果示例代码
Jul 16 Javascript
Node.js抓取中文网页乱码问题和解决方法
Feb 10 Javascript
JavaScript中扩展Array contains方法实例
Aug 23 Javascript
js实现可旋转的立方体模型
Oct 16 Javascript
vue.js element-ui tree树形控件改iview的方法
Mar 29 Javascript
react-native 圆弧拖动进度条实现的示例代码
Apr 12 Javascript
vue-cli3 项目从搭建优化到docker部署的方法
Jan 28 Javascript
基于vue-simple-uploader封装文件分片上传、秒传及断点续传的全局上传插件功能
Feb 23 Vue.js
Vue通过懒加载提升页面响应速度
May 10 Vue.js
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制作简单的内容采集器的代码
2007/11/28 PHP
php使用qr生成二维码的示例分享
2014/01/20 PHP
PHP封装的字符串加密解密函数
2015/12/18 PHP
JavaScript定义类的几种方式总结
2014/01/06 Javascript
js动画效果制件让图片组成动画代码分享
2014/01/14 Javascript
javascript教程:关于if简写语句优化的方法
2014/05/17 Javascript
JavaScript中具名函数的多种调用方式总结
2014/11/08 Javascript
js设置随机切换背景图片的简单实例
2017/11/12 Javascript
微信小程序云开发之使用云函数
2019/05/17 Javascript
解决layer.confirm选择完之后消息框不消失的问题
2019/09/16 Javascript
继承行为在 ES5 与 ES6 中的区别详解
2019/12/24 Javascript
vue穿梭框实现上下移动
2021/01/29 Vue.js
在Python的while循环中使用else以及循环嵌套的用法
2015/10/14 Python
Python过滤列表用法实例分析
2016/04/29 Python
Python中set与frozenset方法和区别详解
2016/05/23 Python
Numpy之文件存取的示例代码
2018/08/03 Python
python时间序列按频率生成日期的方法
2019/05/14 Python
python+selenium实现自动化百度搜索关键词
2019/06/03 Python
python中列表的切片与修改知识点总结
2019/07/23 Python
python加载自定义词典实例
2019/12/06 Python
Tensorflow不支持AVX2指令集的解决方法
2020/02/03 Python
python zip,lambda,map函数代码实例
2020/04/04 Python
PyChon中关于Jekins的详细安装(推荐)
2020/12/28 Python
python excel和yaml文件的读取封装
2021/01/12 Python
一款利用html5和css3实现的3D滚动特效的教程
2015/01/04 HTML / CSS
css3的focus-within选择器的使用
2020/05/11 HTML / CSS
回馈慈善的设计师太阳镜:DIFF eyewear
2019/10/17 全球购物
报社实习生自荐信
2014/01/24 职场文书
捐款倡议书范文
2014/02/02 职场文书
争做文明公民倡议书
2014/08/29 职场文书
2015秋季幼儿园开学通知
2015/07/16 职场文书
爱国主题班会教案
2015/08/14 职场文书
2019通用版导游词范本!
2019/08/07 职场文书
用Python实现Newton插值法
2021/04/17 Python
Python爬虫实战之爬取携程评论
2021/06/02 Python
SQL Server一个字符串拆分多行显示或者多行数据合并成一个字符串
2022/05/25 SQL Server