当前位置:首页 > 日记 > 正文

微信小程序之页面拦截器的示例代码

微信小程序之页面拦截器的示例代码

场景

  • 小程序有52个页面,其中13个页面无需任何身份,另外39个页面需要系统角色。对于这39个页面,如果微信用户没有系统角色,则跳转到登录页。
  • 是否有系统角色信息需要通过异步请求来获取。

需求分析&实现

对需求进行抽象,其实要的就是一个过滤器,对小程序页面的访问进行过滤,符合条件的通过,不符合条件进行其他处理。

使用过php的laravel框架的童鞋,肯定一下子就联想到了laravel框架的http中间件:

HTTP 中间件提供一个方便的机制来过滤进入应用程序的 HTTP 请求,例如,Laravel 默认包含了一个中间件来检验用户身份验证,如果用户没有经过身份验证,中间件会将用户导向登录页面,然而,如果用户通过身份验证,中间件将会允许这个请求进一步继续前进。当然,除了身份验证之外,中间件也可以被用来执行各式各样的任务,CORS 中间件负责替所有即将离开程序的响应加入适当的响应头,一个日志中间件可以记录所有传入应用程序的请求。

令人忧桑的是,微信小程序并没有提供针对Page实例的中间件机制。所以只能从Page实例的生命周期处下手。

对于onLoad,一个页面只会调用一次;对于onShow,每次打开页面(比如小程序从后台转到前台)都会调用一次。

在onLoad或者onShow钩子函数里,对用户身份进行校验,通过后则拉取该页面需要的数据,否则跳转到登录页。

//orderDetail.jsonShow: function () {  let that = this;  //身份校验  service.identityCheck(() => {     //跳转到登录页     wx.redirectTo({      url: "/pages/common/login/login"     });    }, () => {       //获取页面数据等等        that.getDetail(this.orderId);     ...    }  ); },

不过,每个页面都要这样写,重复代码好多啊,侵入性也强。不如用装饰函数(高大上的说法是装饰者模式)来包装一下:

//filter.jsfunction identityFilter(pageObj){  if(pageObj.onShow){    let _onShow = pageObj.onShow;    pageObj.onShow = function(){      service.identityCheck(()=>{        //跳转到登录页        wx.redirectTo({          url: "/pages/common/login/login"        });      },()=>{        //获取页面实例,防止this劫持        let currentInstance = getPageInstance();        _onShow.call(currentInstance);      });    }  }  return pageObj;}function getPageInstance(){  var pages = getCurrentPages();  return pages[pages.length - 1];}exports.identityFilter = identityFilter;

filter.js用以提供过滤器方法,除了现有的用户身份拦截,后续如果需要其他拦截,可以在这个文件增加。然后,在需要用户身份拦截的小程序页面代码里,用filter.identityFilter处理一下就可以了:

//orderDetail.jslet filter = require('filter.js');Page(filter.identityFilter({  ...  onShow: function () {    //获取页面数据等等    this.getDetail(this.orderId);    //...  },  ...}));

使用Promise进行优化

上面的实现中,每次访问页面,都会执行一次获取用户身份的方法(就是上面代码里的service. identityCheck )。其实没有必要,在小程序启动的时候获取一次就行了。也就是说,放在app.js的onLaunch方法里执行。

每个小程序页面实例化时,一般也会执行异步方法,用来获取页面需要的数据。关键在于,我们需要保证,页面的异步方法 必须在 获取用户身份的异步请求 之后执行。

毋容置疑,Promise最擅长处理异步请求的执行顺序了。主子,快放代码粗来:

//app.jsApp({  onLaunch:function(){    let p = new Promise(function(resolve,reject){      service.identityCheck(resolve,reject);    });    this.globalData.promise = p;   },  ...  globalData: {    promise:null,  }  });
//filter.jsconst appData = getApp().globalData;function identityFilter(pageObj){  if(pageObj.onShow){    let _onShow = pageObj.onShow;    pageObj.onShow = function(){      //改动点      appData.promise.then(()=>{        //跳转到登录页        wx.redirectTo({          url: "/pages/common/login/login"        });      },()=>{        //获取页面实例,防止this劫持        let currentInstance = getPageInstance();        _onShow.call(currentInstance);      });    }  }  return pageObj;}

小结

基本实现了小程序页面的用户身份拦截器,但是比起laravel的http中间件还是逊色一些:

  • 需要对每个页面代码包装一层。
  • 即使用户身份校验不通过,小程序也并不会阻塞页面的渲染。假如获取用户身份的异步方法一分钟才执行完,小程序页面还是会展示出来,一分钟之后才跳转到登录页。需要自己增加逻辑,比如在这一分钟内,页面展示空白内容。

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

相关文章

JavaScript自执行函数和jQuery扩展

JavaScript自执行函数和jQuery扩展

扩展方法,函数,执行,详解,电脑软件,我们通常将JS代码写在一个单独的JS文件中,然后在页面中引入该文件。但是,有时候引入后会碰到变量名或函数名与其它JS代码冲突的问题。那么如何解决这个问题呢?作用域隔离。在JS中,作用域是通过函数来划分的,将…

excel纵向求和的教程Excel表格怎么

excel纵向求和的教程Excel表格怎么

教程,纵向,表格,电脑软件,excel,  相信不少朋友都知道该如何利用Excel进行求和了,哪纵向求和又会不会呢?接下来是小编为大家带来的excel纵向求和的教程,供大家参考。excel纵向求和的教程纵向求和步骤1:下面这个表格就是我们需要求和的示例表…

cdr怎么断开闭合路径或线条?

cdr怎么断开闭合路径或线条?

断开,路径,线条,电脑软件,cdr,cdr中想要断开闭合路径,该怎么断开呢?下面我们就来看看详细的教程。1、打开软件。2、用贝塞尔工具画出封闭路径,并填充颜色。3、选择形状工具。4、用形状工具在想要断开的线段处双击加上节点。5、用形状工具选中…

word文档中如何制作文字弧形排列

word文档中如何制作文字弧形排列

文档,排列,文字,弧形,电脑软件,  word中想要制作一个印章,这时候就需要使用弧形排列的文字,word文字怎么弧形排列。以下是小编为您带来的关于word文档制作文字弧形排列,希望对您有所帮助。word文档制作文字弧形排列1、选中插入的艺术字,&OEli…

js 获取今天以及过去日期

js 获取今天以及过去日期

日期,电脑软件,js,1.获取天数, 如昨天,今天,近1星期,近14天function GetDateStr(AddDayCount) { var dd = new Date(); dd.setDate(dd.getDate()+AddDayCount);//获取AddDayCount天后的日期 var y = dd.getFullYear(); var m =…

JS中把函数作为另一函数的参数传递

JS中把函数作为另一函数的参数传递

函数,参数传递,方法,中把,电脑软件,今天在给元素注册事件的时候,使用addEventListener遇到了一个问题,这个好像之前也遇到过,觉得有必要总结一下,就是js函数作为参数引发的问题。首先看以下代码,觉得下面代码有问题吗?是否能达到点击id3对应的元…

Agularjs妙用双向数据绑定实现手风

Agularjs妙用双向数据绑定实现手风

数据绑定,手风琴,妙用,双向,效果,最近在工作总遇到需要实现类似手风琴效果的需求,如下图所示:因为汇总(上半部分)和明细(下面的浅色部分)在不同的情况下显示的字段数量是不一样的,而且还有编辑和展示的状态切换,所以需要自己实现手风琴效果。初步的…

实例详解JavaScript中setTimeout函

实例详解JavaScript中setTimeout函

执行顺序,函数,详解,实例,电脑软件,前言setTimeout,前端工程师必定会打交道的一个函数。它看上去非常的简单,朴实,有着一个很不平凡的名字--定时器。其实网上关于JavaScript中setTimeout的文章很多,但总感觉例子不够直接具体,因此写了个简单的例…

详解tween.js的使用教程

详解tween.js的使用教程

使用教程,详解,电脑软件,js,tween,前面的话TweenJS提供了一个简单但强大的渐变界面。它支持渐变的数字对象属性&CSS样式属性,并允许链接补间动画和行动结合起来,创造出复杂的序列。本文将详细介绍tween.js的使用 概述tween.js允许以平滑的方…

老生常谈js-react组件生命周期

老生常谈js-react组件生命周期

生命周期,组件,老生常谈,电脑软件,react,组件的生命周期可分成三个状态:?Mounting:已插入真实 DOM?Updating:正在被重新渲染?Unmounting:已移出真实 DOM生命周期的方法有:?componentWillMount 在渲染前调用,在客户端也在服务端。?componentDidMo…

老生常谈js中0到底是 true 还是 fa

老生常谈js中0到底是 true 还是 fa

老生常谈,电脑软件,true,js,false,想到一个好玩的,运行如下 javascript :if ('0') alert("'0' is true");if ('0' == false) alert("'0' is false");结果是,两次都 alert 了!那么 '0' 到底是 true 还是 false 呢?答案是:在js做比较…

Excel表格函数出错怎么解决

Excel表格函数出错怎么解决

函数,表格,电脑软件,Excel,  工作中经常使用Excel的朋友可能都会遇到一些看起来似懂非懂的错误值信息:例如# N/A!、#VALUE!、#DIV/O!等等,出现这些错误的原因有很多种,你真的了解它们吗,熟练掌握解决这些错误的方法吗?下面给大家分享Excel中…