Maison  >  Article  >  interface Web  >  Logique du code source frontal de l'applet WeChat et analyse du flux de travail

Logique du code source frontal de l'applet WeChat et analyse du flux de travail

hzc
hzcavant
2020-07-03 11:21:323003parcourir

Après avoir lu le code frontal de l'applet WeChat, mon sang a vraiment bouilli. La logique et la conception du code sont claires en un coup d'œil, il n'y a pas de choses superflues, c'est vraiment simple.

Sans plus tarder, analysons directement le code front-end. Opinions personnelles, il peut y avoir quelques omissions, c'est à titre indicatif seulement.

Structure de base du fichier :

Premier coup d'oeil à l'entrée app.js, app (obj) enregistre un petit programme. Accepte un paramètre d'objet, qui spécifie la fonction de cycle de vie de l'applet, etc. D'autres fichiers peuvent obtenir l'instance d'application via la méthode globale getApp(), puis appeler directement ses propriétés ou méthodes, telles que (getApp().globalData)

//app.jsApp({
  onLaunch: function () {    //调用API从本地缓存中获取数据
    var logs = wx.getStorageSync('logs') || []
    logs.unshift(Date.now())
    wx.setStorageSync('logs', logs)
  },
  getUserInfo:function(cb){    var that = this
    if(this.globalData.userInfo){      typeof cb == "function" && cb(this.globalData.userInfo)
    }else{      //调用登录接口      wx.login({
        success: function () {
          wx.getUserInfo({
            success: function (res) {
              that.globalData.userInfo = res.userInfo              typeof cb == "function" && cb(that.globalData.userInfo)
            }
          })
        }
      })
    }
  },
  globalData:{
    userInfo:null
  }
})

Je comprends que app.js est le fichier d'initialisation de l'entrée. C'est également l'endroit où l'expansion globale de l'API est fournie. Analysons les différentes méthodes et attributs qui l'accompagnent

la fonction de hook onLaunch sera automatiquement exécutée une fois l'initialisation du mini-programme terminée, puis si vous ne l'appelez pas activement pendant le cycle de vie du mini programme au lancement, il ne sera pas exécuté. La fonction

var logs = wx.getStorageSync('logs') || []
获取本地缓存中的logs属性,如果值为空,那么设置logs=[] 与HTML5中的localStorage作用相似

logs.unshift(Date.now()) 当前登录时间添加到数组中

wx.getStorageSync('logs')获取本地缓存数据

getUserInfo , comme son nom l'indique, consiste à obtenir des informations sur l'utilisateur connecté. Cette fonction équivaut à fournir une interface pour obtenir des informations sur l'utilisateur. Les autres pages ne seront exécutées que si. appelé. D'autres pages appellent cette méthode via getApp().getUserInfo(function(userinfo){console.log(userinfo);}) pour obtenir des informations sur l'utilisateur. L'objet

getUserInfo:function(cb){//参数为cb,类型为函数
    var that = this
    if(this.globalData.userInfo){//用户信息不为空
      typeof cb == "function" && cb(this.globalData.userInfo)//如果参数cb的类型为函数,那么执行cb,获取用户信息;
    }else{//如果用户信息为空,也就是说第一次调用getUserInfo,会调用用户登录接口。      wx.login({
        success: function () {
          wx.getUserInfo({
            success: function (res) {
         console.log(res)
              that.globalData.userInfo = res.userInfo//把用户信息赋给globalData,如果再次调用getUserInfo函数的时候,不需要调用登录接口
              typeof cb == "function" && cb(that.globalData.userInfo)//如果参数cb类型为函数,执行cb,获取用户信息            }
          })
        }
      })
    }
  }

globalData est utilisé pour stocker des données globales, qui sont appelées à d'autres endroits

puis analyser brièvement le fichier app.json . La fonction de ce fichier est de configurer globalement l'applet WeChat, de déterminer le chemin du fichier d'échange, les performances de la fenêtre, de définir le délai d'expiration du réseau, de définir plusieurs onglets, etc.

La chose la plus importante. is pages Attribut , obligatoire, est un tableau. Les éléments du tableau sont des chemins de fichiers de chaîne, spécifiant les pages dont se compose le mini-programme. Le premier élément doit être la page initiale du mini-programme. .

{  "pages":[    "pages/index/index",    "pages/logs/logs"
  ],  "window":{    "backgroundTextStyle":"light",    "navigationBarBackgroundColor": "#fff",    "navigationBarTitleText": "WeChat",    "navigationBarTextStyle":"black"
  }
}

Jetez ensuite un œil à l'index du projet et aux dossiers de journaux. Le projet initial de l'applet WeChat place les js, wxss et wxml liés à chaque page dans leurs propres fichiers, de sorte que la structure semble beaucoup plus claire.

Regardons d'abord le dossier index, qui est la page initiale du mini programme. Sous le dossier index se trouvent trois petits fichiers : index.js, index.wxml et index.wxss. Le mini-programme sépare les codes js, css et html et les place dans des fichiers séparés, chacun effectuant ses propres tâches. Les noms des fichiers js et des feuilles de style doivent être cohérents avec le nom du fichier wxml du dossier actuel, afin de garantir que les effets de js et des feuilles de style puissent être affichés sur la page. J'apprécie ce type de concept de conception, soigné et uniforme, avec des responsabilités claires et réduisant la complexité de la conception du code.

index.wxml, il s'agit d'un fichier modèle commun, basé sur les données, avec un frontal mvc, mvvm les développeurs du projet le connaîtront, après tout, il est développé sur la base de react .  

925a1f3a4f482e42fdef638109e2ed51
8f757650f3432f76274b21f6b4c1fc9a//视图容器
  6669428ff968f9fab7cc4603253a5a2b
  //bindtap为容器绑定点击触摸事件,在触摸离开时触发bindViewTap事件处理函数,bindViewTap通过index.js page()设置添加
    3d048a2b9ff2c224f697c32c3f24dc4ef8e950ebc6c1ea27f76cf997b9216fe6
    //大双括号的变量来自于index.js的data对象解析成对应的值,而且是实时的
    277932af4e9676f3c247b090853cb2a7{{userInfo.nickName}}273e21371c5d5e701d3c98517a0bfa41
  de5f4c1163741e920c998275338d29b2
  a675b38a74d9bf96543e9ed6fb1ac95e
    2602ac4605743953d5d7d0fd8c968325{{motto}}273e21371c5d5e701d3c98517a0bfa41
  de5f4c1163741e920c998275338d29b2
de5f4c1163741e920c998275338d29b2

index.js est presque la même que l'utilisation de react Vous pouvez changer la soupe sans changer le médicament. page() pour enregistrer une page. Accepte un paramètre OBJECT, qui spécifie les données initiales de la page, la fonction de cycle de vie, la fonction de gestion des événements, etc. Le fichier

var app = getApp() // 获取入口文件app的应用实例Page({
  data: {
    motto: 'Hello World',
    userInfo: {}
  },  //自定义事件处理函数,点击.userinfo的容易触发此函数
  bindViewTap: function() {
    wx.navigateTo({//全局对象wx的跳转页面方法
      url: '../logs/logs'
    })
  },
  onLoad: function () {//发生页面加载时,自动触发该生命周期函数
    console.log('onLoad')    var that = this
    //调用应用实例的方法获取全局数据
    app.getUserInfo(function(userInfo){      //更新数据,页面自动渲染      that.setData({
        userInfo:userInfo
      })
    })
  }
})

index.wxss affiche uniquement la page actuelle à laquelle il appartient et écrasera l'application globale. .wxss avec le même style.

Analysons à nouveaulogsdossier log, logs Le dossier est logs.wxml, logs.js, logs.wxss, logs.json, assurez-vous de la même manière qu'ils portent le même nom pour terminer le rendu de l'effet.

logs.wxmlFichier

<!--logs.wxml-->
<view class="container log-list">
  <block wx:for="{{logs}}" wx:for-item="log">
  //block容器作用,无其他实际含义。wx:for作用:遍历logs数组,遍历多少次,block块就会复制多少次,for-item等同于为
      遍历元素起一个变量名,方便引用。
    <text class="log-item">{{index + 1}}. {{log}}</text>
  </block>
</view>

Fichier logs.js

//logs.js
var util = require(&#39;../../utils/util.js&#39;) 
//util.js相当于一个函数库,我们可以在这个文件内自定义扩展和封装一些常用的函数和方法
Page({
  data: {
    logs: []
  },
  onLoad: function () {
    this.setData({
      logs: (wx.getStorageSync(&#39;logs&#39;) || []).map(function (log) {
      //通过wx.getStorageSync获取本地缓存的logs日志数据
        return util.formatTime(new Date(log))//日期格式化
      })
    })
  }
})

fichier logs.json

{
   "navigationBarTitleText": "查看启动日志"   //当前页面配置文件,设置window当前页面顶部导航栏标题等相关内容
} 

基本页面结构和逻辑就这么简单,暴露给我们的没有一点令人费解的东西。

小程序还提供了很多官方组件和API等待我们深挖,加油吧,少年!小程序官方文档地址

推荐教程:《微信小程序

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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer
Article précédent:utilisation des appels jsArticle suivant:utilisation des appels js