Detaillierte Erläuterung des Front-End-Quellcodes des WeChat-Miniprogramms und Beispielanalyse

高洛峰
Freigeben: 2017-03-20 09:42:01
Original
3106 Leute haben es durchsucht

In diesem Artikel werden hauptsächlich relevante Informationen zum Front-End-Quellcode des WeChat Mini-Programms vorgestellt. Bedürftige Freunde können sich auf die

Front-End-Quelle des WeChat Mini-Programms beziehen Codelogik und Workflow

Nachdem ich den Front-End-Code des WeChat-Applets gelesen hatte, kochte mein Blut wirklich. Die Codelogik und das Design sind auf einen Blick klar, es gibt keine überflüssigen Dinge, es ist wirklich einfach.

Lassen Sie uns ohne weitere Umschweife den Front-End-Code direkt analysieren. Persönliche Meinungen, es kann einige Auslassungen geben, sie dienen nur als Referenz.

Grundstruktur der Datei:

Detaillierte Erläuterung des Front-End-Quellcodes des WeChat-Miniprogramms und Beispielanalyse

Erster Blick auf die Eingangs-App.js, app ( obj) registriert ein Miniprogramm. Akzeptiert einen Objekt-Parameter, der den Lebenszyklus Funktion usw. des Applets angibt. Andere Dateien können die App-Instanz über die globale Methode getApp() abrufen und dann deren -Attribute oder Methoden wie (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
 }
})
Nach dem Login kopieren
Ich verstehe, dass app.js die Eintragsinitialisierungsdatei ist und dort auch die globale API-Erweiterung bereitgestellt wird. Lassen Sie uns die verschiedenen Methoden und Attribute analysieren, die damit einhergehen.

onLaunch-Hook-Funktion wird automatisch einmal ausgeführt, nachdem die Initialisierung des Miniprogramms abgeschlossen ist, und dann, wenn Sie sie währenddessen nicht aktiv aufrufen Mini-Programmlebenszyklus onLaunch, es wird nicht ausgeführt.

var logs = wx.getStorageSync('logs') || [] Rufen Sie das Protokollattribut im lokalen Cache ab. Wenn der Wert leer ist, legen Sie logs=[] und

HTML5 fest localStorage hat eine ähnliche Funktion

logs.unshift(Date.now()) Die aktuelle Anmeldezeit wird dem

Array hinzugefügt

wx.setStorageSync('logs', logs) Die Daten werden im lokalen Cache gespeichert. Da wx ein globales

-Objekt ist, können Sie wx.getStorageSync('logs') direkt in anderen Dateien aufrufen, um die lokalen -Cache-Daten <🎜 zu erhalten >

getUserInfo-Funktion

dient, wie der Name schon sagt, dazu, angemeldete Benutzerinformationen abzurufen. Diese Funktion entspricht der Bereitstellung einer Schnittstelle zum Abrufen von Benutzerinformationen ausgeführt, sofern nicht aufgerufen. Andere Seiten rufen diese Methode über getApp().getUserInfo(function(userinfo){console.log(userinfo);}) auf, um Benutzerinformationen abzurufen.

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,获取用户信息
      }
     })
    }
   })
  }
 }
Nach dem Login kopieren
Das globalData

-Objekt wird verwendet, um globale Daten an anderen Stellen zu speichern und dann die App kurz zu analysieren.json Datei, die Funktion dieser Datei besteht darin, das WeChat-Applet global zu konfigurieren, den Pfad der Auslagerungsdatei, die Fensterleistung, das Festlegen des Netzwerk-Timeouts, das Festlegen mehrerer Registerkarten usw. zu bestimmen.

Das Wichtigste Ding ist das pages-Attribut , erforderlich, ist ein Array. Die Elemente im Array sind -String-

-Dateipfade, die angeben, aus welchen Seiten das Miniprogramm besteht Seite des Miniprogramms.

Dann schauen Sie sich den Projektindex und die Protokollordner an. Das ursprüngliche Projekt des WeChat-Applets legt die js, wxss

und w
{
 "pages":[
  "pages/index/index",
  "pages/logs/logs"
 ],
 "window":{
  "backgroundTextStyle":"light",
  "navigationBarBackgroundColor": "#fff",
  "navigationBarTitleText": "WeChat",
  "navigationBarTextStyle":"black"
 }
}
Nach dem Login kopieren
xml

für jede Seite in eigenen Dateien ab, sodass die Struktur viel klarer aussieht. Schauen wir uns zunächst den Indexordner an, der die Startseite des Miniprogramms darstellt. Unter dem Indexordner befinden sich drei kleine Dateien: index.js, index.wxml und index.wxss. Das Miniprogramm trennt JS-, CSS- und HTML-Codes und legt sie in separaten Dateien ab, wobei jede ihre eigenen Aufgaben erfüllt. Die Namen der JS- und Stylesheet-Dateien müssen mit dem WXML-Dateinamen des aktuellen Ordners übereinstimmen, um sicherzustellen, dass die Auswirkungen von JS und Stylesheets auf der Seite angezeigt werden können. Ich schätze ein solches Designkonzept, das sauber und einheitlich ist, klare Verantwortlichkeiten aufweist und die Komplexität des Codedesigns reduziert.  index.wxml, dies ist eine allgemeine Vorlagendatei, Daten

Treiber

, mit der diejenigen vertraut sind, die Front-End-

mvc

- und mvvm-Projekte entwickelt haben Dies ist schließlich auf der Grundlage von Reagieren entwickelt. ​

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

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

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

  logs.wxml文件

  logs.js 文件

  logs.json文件

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

更多Detaillierte Erläuterung des Front-End-Quellcodes des WeChat-Miniprogramms und Beispielanalyse相关文章请关注PHP中文网!

相关文章:

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

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

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

Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung des Front-End-Quellcodes des WeChat-Miniprogramms und Beispielanalyse. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage