検索
ホームページWeChat アプレットミニプログラム開発WeChat ミニ プログラムのフロントエンド ソース コード ロジックとワークフローの詳細な説明

この記事では、主に WeChat アプレットのフロントエンド ソース コード ロジックとワークフローに関する関連情報を紹介します。また、テキストの基本的な構造図とサンプル コードも提供します。非常に優れており、参考になります。必要な方は参照してください

早速、フロントエンド コードを直接分析してみましょう。

ファイルの基本構造:

WeChat ミニ プログラムのフロントエンド ソース コード ロジックとワークフローの詳細な説明

まず入り口のアプリを見てください。js、アプリ(obj)は小さなプログラムを登録します。アプレットのライフサイクル関数などを指定するobjectパラメータを受け入れます。他のファイルは、グローバル メソッド getApp() を通じてアプリ インスタンスを取得し、その プロパティ または (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
}
})

app.js はエントリ初期化ファイル。グローバル API 拡張が提供される場所でもあります。それに付属するいくつかのメソッドと属性を分析してみましょう。 onLaunch フック関数は、ミニ プログラムが初期化された後、自動的に実行されます。その後、ミニ プログラムのライフ サイクル中に、onLaunch を積極的に呼び出さなければ、この関数は実行されません。 。

var logs = wx.getStorageSync('logs') || [] 値が空の場合、logs=[] を設定します。これは、
HTML5

ログの localStorage と同様です。 .unshift( Date.now()) 現在のログイン時刻が

arraywx.setStorageSync('logs', logs) に追加され、データがローカル キャッシュに保存されます。wx はグローバル オブジェクト であるため、次のことが可能です。他のファイルで wx を直接呼び出します。 getStorageSync('logs') ローカルのキャッシュ データを取得します。 getUserInfo 関数は、名前が示すように、ログインしているユーザーの情報を取得するためのインターフェイスを提供することに相当します。他のページは呼び出されない限り実行されません。他のページは、getApp().getUserInfo(function(userinfo){console.log(userinfo);}) を通じてこのメソッドを呼び出し、ユーザー情報を取得します。

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 オブジェクトは、他の場所で

を呼び出して、app.

json
ファイルを簡単に分析できるグローバル データを保存するために使用されます。このファイルの機能は、WeChat をグローバルに構成することです。アプレットを作成し、ページ ファイルを決定します。パス、ウィンドウ パフォーマンス、ネットワーク タイムアウトの設定、複数のタブの設定など、

最も重要なのは、配列内の要素である、pages 属性です。文字列特定のファイル パス。ミニ プログラムのどのページが構成であるかを指定します。最初の項目はミニ プログラムの最初のページである必要があります。

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

次に、プロジェクトのインデックス フォルダーとログ フォルダーを見てください。 WeChat ミニ プログラムの初期プロジェクトでは、各ページに関連する js、

wxss

、および w

xml

を独自のファイルに配置するため、構造がより明確に見えます。

まず、ミニプログラムの最初のページであるインデックスフォルダーを見てみましょう。 Index フォルダーの下には、index.js、index.wxml、index.wxss の 3 つの小さなファイルがあります。ミニ プログラムは、js、css、および html コードを分離して別個のファイルに配置し、それぞれが独自の役割を実行します。 js およびスタイル シートの効果をページに確実に表示できるように、js およびスタイル シートのファイル名は、現在のフォルダーの wxml ファイル名と一致している必要があります。私はこの種の設計コンセプトを高く評価しています。それは、きちんとしていて統一されており、責任が明確で、コード設計の複雑さが軽減されます。
index.wxml、これは共通のテンプレートファイル、データ

ドライバー

です。これは、フロントエンド
mvc

やmvvmプロジェクトを開発したことがある方には馴染みがあるでしょう、結局のところ、これは

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、使い方はreactとほぼ同じで、薬は変えずにスープを変えるだけです。 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.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当前页面顶部导航栏标题等相关内容
}

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

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

以上がWeChat ミニ プログラムのフロントエンド ソース コード ロジックとワークフローの詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター