


Explication détaillée de l'intercepteur de page pour le développement de l'applet WeChat
May 29, 2018 am 09:51 AMCet article présente principalement l'exemple de code de l'intercepteur de page de l'applet WeChat. L'éditeur pense qu'il est plut?t bon, je vais donc le partager avec vous maintenant et le donner comme référence. Venez jeter un ?il avec l'éditeur
Scénario
Le mini programme compte 52 pages dont 13 ne nécessitent aucune Identity , 39 autres pages nécessitent des r?les système. Pour ces 39 pages, si l'utilisateur WeChat n'a pas de r?le système, il accédera à la page de connexion.
S'il existe des informations sur le r?le du système qui doivent être obtenues via des requêtes asynchrones.
Analyse et mise en ?uvre des exigences
Résumer les exigences En fait, ce qu'il faut, c'est un filtre pour accéder à la page du mini programme. . Filtrez, transmettez ceux qui remplissent les conditions et effectuez d'autres traitements s'ils ne remplissent pas les conditions.
Les chaussures pour enfants qui ont utilisé le framework laravel de PHP doivent immédiatement penser au middleware http du framework laravel?:
Le middleware HTTP fournit un mécanisme pratique pour filtrer les requêtes HTTP entrantes, par exemple. Laravel inclut un middleware par défaut pour vérifier l'authentification de l'utilisateur. Si l'utilisateur n'est pas authentifié, le middleware dirigera l'utilisateur vers la page de connexion. Cependant, si l'utilisateur est authentifié, le middleware autorisera la demande. Bien entendu, en plus de l'authentification, le middleware peut également être utilisé pour effectuer diverses taches. Le middleware CORS est chargé d'ajouter des en-têtes de réponse appropriés à toutes les réponses qui sont sur le point de quitter le programme. Un middleware de journalisation peut enregistrer toutes les applications entrantes. demande.
Ce qui est inquiétant, c'est que l'applet WeChat ne fournit pas de mécanisme middleware pour les instances de Page. Nous ne pouvons donc partir que du cycle de vie de l’instance Page.
Pour onLoad, elle ne sera appelée qu'une seule fois pour une page ; pour onShow, elle sera appelée une fois à chaque ouverture de la page (par exemple, l'applet passe de l'arrière-plan au premier plan).
Dans la fonction hook onLoad ou onShow, vérifiez l'identité de l'utilisateur. Si elle est transmise, extrayez les données requises pour la page, sinon passez à la page de connexion.
//orderDetail.js onShow: function () { let that = this; //身份校驗(yàn) service.identityCheck(() => { //跳轉(zhuǎn)到登錄頁(yè) wx.redirectTo({ url: "/pages/common/login/login" }); }, () => { //獲取頁(yè)面數(shù)據(jù)等等 that.getDetail(this.orderId); ... } ); },
Cependant, chaque page doit être écrite comme ?a. Il y a beaucoup de code répété et c'est aussi très intrusif. Il est préférable de l'envelopper d'une fonction décorative (le terme le plus grand est le motif décorateur)?:
//filter.js function identityFilter(pageObj){ if(pageObj.onShow){ let _onShow = pageObj.onShow; pageObj.onShow = function(){ service.identityCheck(()=>{ //跳轉(zhuǎn)到登錄頁(yè) wx.redirectTo({ url: "/pages/common/login/login" }); },()=>{ //獲取頁(yè)面實(shí)例,防止this劫持 let currentInstance = getPageInstance(); _onShow.call(currentInstance); }); } } return pageObj; } function getPageInstance(){ var pages = getCurrentPages(); return pages[pages.length - 1]; } exports.identityFilter = identityFilter;
filter.js
pour fournir des méthodes de filtrage, en plus de l'interception de l'identité de l'utilisateur existante, si d'autres interceptions sont nécessaire plus tard, peut être ajouté dans ce fichier. Ensuite, dans le code de la page de l'applet qui nécessite l'interception de l'identité de l'utilisateur, utilisez simplement filter.identityFilter
pour le traiter?:
//orderDetail.js let filter = require('filter.js'); Page(filter.identityFilter({ ... onShow: function () { //獲取頁(yè)面數(shù)據(jù)等等 this.getDetail(this.orderId); //... }, ... }));
Utilisez Promise pour optimiser
Dans l'implémentation ci-dessus, chaque fois que la page est accédée, la méthode d'obtention de l'identité de l'utilisateur sera exécutée (c'est-à-dire service.identityCheck dans le code ci-dessus). En fait, ce n'est pas nécessaire, il suffit de l'obtenir une fois au démarrage du mini programme. En d'autres termes, exécutez-le dans la méthode onLaunch de app.js.
Lorsque chaque page de mini programme est instanciée, une méthode asynchrone est généralement exécutée pour obtenir les données requises par la page. La clé est que nous devons nous assurer que la méthode asynchrone de la page doit être exécutée après la requête asynchrone pour obtenir l'identité de l'utilisateur.
Il ne fait aucun doute que Promise est le meilleur pour gérer l'ordre d'exécution des requêtes asynchrones. Ma?tre, parcourons rapidement le code?:
//app.js App({ onLaunch:function(){ let p = new Promise(function(resolve,reject){ service.identityCheck(resolve,reject); }); this.globalData.promise = p; }, ... globalData: { promise:null, } });
//filter.js const appData = getApp().globalData; function identityFilter(pageObj){ if(pageObj.onShow){ let _onShow = pageObj.onShow; pageObj.onShow = function(){ //改動(dòng)點(diǎn) appData.promise.then(()=>{ //跳轉(zhuǎn)到登錄頁(yè) wx.redirectTo({ url: "/pages/common/login/login" }); },()=>{ //獲取頁(yè)面實(shí)例,防止this劫持 let currentInstance = getPageInstance(); _onShow.call(currentInstance); }); } } return pageObj; }
Résumé
Implémente essentiellement l'intercepteur d'identité utilisateur de la page du mini programme, mais c'est plus compliqué que le middleware http de Laravel est toujours inférieur :
nécessite une couche d'emballage pour chaque code de page.
Même si la vérification de l'identité de l'utilisateur échoue, le mini programme ne bloquera pas le rendu de la page. Si la méthode asynchrone pour obtenir l'identité de l'utilisateur prend une minute, la page du mini-programme sera toujours affichée et elle passera à la page de connexion après une minute. Vous devez ajouter de la logique vous-même, par exemple, pendant cette minute, la page affiche un contenu vide.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Article chaud

Outils chauds

Bloc-notes++7.3.1
éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Le système d'exploitation Windows est l'un des systèmes d'exploitation les plus populaires au monde et sa nouvelle version Win11 a beaucoup attiré l'attention. Dans le système Win11, l'obtention des droits d'administrateur est une opération importante. Les droits d'administrateur permettent aux utilisateurs d'effectuer davantage d'opérations et de paramètres sur le système. Cet article présentera en détail comment obtenir les autorisations d'administrateur dans le système Win11 et comment gérer efficacement les autorisations. Dans le système Win11, les droits d'administrateur sont divisés en deux types : administrateur local et administrateur de domaine. Un administrateur local dispose de tous les droits d'administration sur l'ordinateur local

Explication détaillée de la fonction mode en C++ En statistiques, le mode fait référence à la valeur qui appara?t le plus fréquemment dans un ensemble de données. En langage C++, nous pouvons trouver le mode dans n’importe quel ensemble de données en écrivant une fonction de mode. La fonction mode peut être implémentée de nombreuses manières différentes, deux des méthodes couramment utilisées seront présentées en détail ci-dessous. La première méthode consiste à utiliser une table de hachage pour compter le nombre d'occurrences de chaque nombre. Tout d’abord, nous devons définir une table de hachage avec chaque nombre comme clé et le nombre d’occurrences comme valeur. Ensuite, pour un ensemble de données donné, nous exécutons

Explication détaillée de l'opération de division dans OracleSQL Dans OracleSQL, l'opération de division est une opération mathématique courante et importante, utilisée pour calculer le résultat de la division de deux nombres. La division est souvent utilisée dans les requêtes de bases de données. Comprendre le fonctionnement de la division et son utilisation dans OracleSQL est donc l'une des compétences essentielles des développeurs de bases de données. Cet article discutera en détail des connaissances pertinentes sur les opérations de division dans OracleSQL et fournira des exemples de code spécifiques pour référence aux lecteurs. 1. Opération de division dans OracleSQL

Implémentation d'effets de retournement de cartes dans les mini-programmes WeChat Dans les mini-programmes WeChat, la mise en ?uvre d'effets de retournement de cartes est un effet d'animation courant qui peut améliorer l'expérience utilisateur et l'attractivité des interactions d'interface. Ce qui suit présentera en détail comment implémenter l'effet de retournement de carte dans l'applet WeChat et fournira des exemples de code pertinents. Tout d'abord, vous devez définir deux éléments de carte dans le fichier de mise en page du mini-programme, un pour afficher le contenu avant et un pour afficher le contenu arrière. L'exemple de code spécifique est le suivant?: <!--index.wxml-. ->&l

Explication détaillée de la fonction reste en C++ En C++, l'opérateur reste (%) est utilisé pour calculer le reste de la division de deux nombres. Il s'agit d'un opérateur binaire dont les opérandes peuvent être n'importe quel type entier (y compris char, short, int, long, etc.) ou un type nombre à virgule flottante (tel que float, double). L'opérateur reste renvoie un résultat du même signe que le dividende. Par exemple, pour l'opération de reste des entiers, nous pouvons utiliser le code suivant pour implémenter : inta=10;intb=3;

L'opérateur modulo (%) en PHP est utilisé pour obtenir le reste de la division de deux nombres. Dans cet article, nous discuterons en détail du r?le et de l'utilisation de l'opérateur modulo et fournirons des exemples de code spécifiques pour aider les lecteurs à mieux comprendre. 1. Le r?le de l'opérateur modulo En mathématiques, lorsqu'on divise un entier par un autre entier, on obtient un quotient et un reste. Par exemple, lorsque l’on divise 10 par 3, le quotient est 3 et le reste est 1. L'opérateur modulo est utilisé pour obtenir ce reste. 2. Utilisation de l'opérateur modulo En PHP, utilisez le symbole % pour représenter le module

Numpy est une bibliothèque de calcul scientifique Python qui fournit une multitude de fonctions et d'outils d'opération de tableau. Lors de la mise à niveau de la version Numpy, vous devez interroger la version actuelle pour garantir la compatibilité. Cet article présentera en détail la méthode de requête de version Numpy et fournira des exemples de code spécifiques. Méthode 1?: utilisez le code Python pour interroger la version Numpy Vous pouvez facilement interroger la version Numpy à l'aide du code Python. Voici la méthode d'implémentation et un exemple de code?: importnumpyasnpprint(np.

Explication détaillée de la fonction d'appel système Linux system() L'appel système est une partie très importante du système d'exploitation Linux. Il fournit un moyen d'interagir avec le noyau système. Parmi elles, la fonction system() est l’une des fonctions d’appel système couramment utilisées. Cet article présentera en détail l’utilisation de la fonction system() et fournira des exemples de code correspondants. Concepts de base des appels système Les appels système sont un moyen permettant aux programmes utilisateur d'interagir avec le noyau du système d'exploitation. Les programmes utilisateur demandent au système d'exploitation en appelant des fonctions d'appel système
