Maison  >  Article  >  Applet WeChat  >  Explication détaillée du code source frontal du mini-programme WeChat et exemple d'analyse

Explication détaillée du code source frontal du mini-programme WeChat et exemple d'analyse

高洛峰
高洛峰original
2017-03-20 09:42:013091parcourir

Cet article présente principalement les informations pertinentes sur le Programme WeChat Mini, une explication détaillée du code source et des exemples d'analyse. Les amis dans le besoin peuvent se référer à la source frontale du

Programme WeChat Mini. logique du code et flux de travail

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 :

Explication détaillée du code source frontal du mini-programme WeChat et exemple danalyse

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

//app.js
App({
 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 d'entrée et c'est également là que 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é.

var logs = wx.getStorageSync('logs') || [] Obtenez l'attribut logs dans le cache local. Si la valeur est vide, définissez logs=[] et HTML5. localStorage a une fonction similaire

logs.unshift(Date.now()) L'heure de connexion actuelle est ajoutée au tableau

wx.setStorageSync('logs', logs) Les données Stockez-les dans le cache local. Parce que wx est un objet global, vous pouvez directement appeler wx.getStorageSync('logs') dans d'autres fichiers pour obtenir les données du cache local

La fonction 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 le seront pas. exécuté à moins d’être appelé. D'autres pages appellent cette méthode via getApp().getUserInfo(function(userinfo){console.log(userinfo);}) pour obtenir des informations sur l'utilisateur.

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,获取用户信息
      }
     })
    }
   })
  }
 }

L'objet globalData est utilisé pour stocker des données globales. Appelez

à d'autres endroits, puis analysez brièvement l'application.json<.> fichier , 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. Le plus important la chose est que l'attribut

pages

, obligatoire, est un tableau. Les éléments du tableau sont des chaînes chemins de fichiers, spécifiant de quelles pages se compose le mini-programme. page du mini programme.

{
 "pages":[
  "pages/index/index",
  "pages/logs/logs"
 ],
 "window":{
  "backgroundTextStyle":"light",
  "navigationBarBackgroundColor": "#fff",
  "navigationBarTitleText": "WeChat",
  "navigationBarTextStyle":"black"
 }
}
Jetez ensuite un œil aux dossiers d'index et de journaux du projet. Le projet initial de l'applet WeChat place les js,

wxss et wxml liés à chaque page dans leurs propres fichiers, afin que la structure paraisse 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, data

driver, ceux qui ont développé le front-end mvc, le projet mvvm sera familier avec ceci, après tout, il est développé sur la base de react. ​

<!--index.wxml-->
<view class="container">//视图容器
 <view bindtap="bindViewTap" class="userinfo">//bindtap为容器绑定点击触摸事件,在触摸离开时触发bindViewTap事件处理函数,bindViewTap通过index.js page()设置添加
  <image class="userinfo-avatar" src="{{userInfo.avatarUrl}}" background-size="cover"></image>//大双括号的变量来自于index.js的data对象解析成对应的值,而且是实时的
  <text class="userinfo-nickname">{{userInfo.nickName}}</text>
 </view>
 <view class="usermotto">
  <text class="user-motto">{{motto}}</text>
 </view>
</view>

  index.js,与reaact用法几无二异,换汤不换药。page()来注册一个页面。接受一个 OBJECT 参数,其指定页面的初始数据、生命周期函数、事件处理函数等。

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

  index.wxss文件只渲染当前所属页面,会覆盖全局app.wxss同一样式。

     再分析下logs日志文件夹,logs文件夹下为logs.wxml、logs.js、logs.wxss、logs.json,同理保证同名,才能完成效果渲染。

     logs.wxml文件

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

  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))//日期格式化
   })
  })
 }
})

  logs.json文件

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

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

更多Explication détaillée du code source frontal du mini-programme WeChat et exemple danalyse相关文章请关注PHP中文网!

相关文章:

微信官方开发者工具如何导入小程序源码demo

四大微信小程序开发工具测评结果出炉

微信小程序开发工具 for mac 简介及快捷键

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:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn