這篇文章主要介紹了微信 小程序前端源碼詳解及實例分析的相關(guān)資料,需要的朋友可以參考下
微信小程序前端源碼邏輯和工作流
看完微信小程序的前端代碼真的讓我熱血沸騰啊,代碼邏輯和設(shè)計一目了然,沒有多余的東西,真的是大道至簡。
廢話不多說,直接分析前端代碼。個人觀點,難免有疏漏,僅供參考。
文件基本結(jié)構(gòu):
先看入口app.js,app(obj)注冊一個小程序。接受一個 object 參數(shù),其指定小程序的生命周期函數(shù)等。其他文件可以通過全局方法getApp()獲取app實例,進(jìn)而直接調(diào)用它的屬性或方法,例如(getApp().globalData)
//app.js App({ onLaunch: function () { //調(diào)用API從本地緩存中獲取數(shù)據(jù) 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{ //調(diào)用登錄接口 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鉤子函數(shù)會在小程序初始化完成后會自動執(zhí)行一次,然后在小程序生命周期里如果你不主動調(diào)用onLaunch,它就不會在執(zhí)行。
var logs = wx.getStorageSync('logs') || []獲取本地緩存中的logs屬性,如果值為空,那么設(shè)置logs=[] 與HTML5中的localStorage作用相似
logs.unshift(Date.now()) 當(dāng)前登錄時間添加到數(shù)組中
wx.setStorageSync('logs', logs) 將數(shù)據(jù)存入本地緩存,因為wx為全局對象,所以可以在其他文件中直接調(diào)用wx.getStorageSync('logs')獲取本地緩存數(shù)據(jù)
getUserInfo函數(shù),顧名思義就是獲取登錄用戶信息,相當(dāng)于此函數(shù)提供了獲取用戶信息的接口,其他頁面不調(diào)用自然不會執(zhí)行。其他頁面通過getApp().getUserInfo(function(userinfo){console.log(userinfo);})這種方式調(diào)用該方法,獲取用戶信息。
getUserInfo:function(cb){//參數(shù)為cb,類型為函數(shù) var that = this if(this.globalData.userInfo){//用戶信息不為空 typeof cb == "function" && cb(this.globalData.userInfo)//如果參數(shù)cb的類型為函數(shù),那么執(zhí)行cb,獲取用戶信息; }else{//如果用戶信息為空,也就是說第一次調(diào)用getUserInfo,會調(diào)用用戶登錄接口。 wx.login({ success: function () { wx.getUserInfo({ success: function (res) { console.log(res) that.globalData.userInfo = res.userInfo//把用戶信息賦給globalData,如果再次調(diào)用getUserInfo函數(shù)的時候,不需要調(diào)用登錄接口 typeof cb == "function" && cb(that.globalData.userInfo)//如果參數(shù)cb類型為函數(shù),執(zhí)行cb,獲取用戶信息 } }) } }) } }
globalData對象用來存儲全局?jǐn)?shù)據(jù),在其他地方調(diào)用
然后簡要分析下app.json文件,該文件作用是對微信小程序進(jìn)行全局配置,決定頁面文件的路徑、窗口表現(xiàn)、設(shè)置網(wǎng)絡(luò)超時時間、設(shè)置多 tab 等、
最重要的是pages屬性,必填,為數(shù)組,數(shù)組內(nèi)的元素為字符串性文件路徑,指定小程序由哪些頁面組成,第一項必須是小程序初始頁面。
{ "pages":[ "pages/index/index", "pages/logs/logs" ], "window":{ "backgroundTextStyle":"light", "navigationBarBackgroundColor": "#fff", "navigationBarTitleText": "WeChat", "navigationBarTextStyle":"black" } }
然后來看下項目index和logs文件夾。微信小程序初始項目把每個頁面相關(guān)的js、wxss、wxml放在各自的文件,這樣看起來結(jié)構(gòu)清晰明朗很多。
先來看index文件夾,即小程序初始頁面。index文件夾下為index.js、index.wxml、index.wxss三個小文件。小程序把js、css、html代碼分離開來,放在獨自的文件里,各司其職。js和樣式表文件名必須與當(dāng)前文件夾的wxml文件名保持一致,這樣才能保證js和樣式表的效果能夠在頁面中顯現(xiàn)出來。我很欣賞這樣的設(shè)計理念,整齊劃一,職責(zé)明確,減輕代碼設(shè)計復(fù)雜度。
index.wxml,這就是常見的模板文件,數(shù)據(jù)驅(qū)動,有過前端mvc、mvvm項目開發(fā)的對這個一定不會陌生,畢竟這是基于react開發(fā)的?! ?/span>
<!--index.wxml--> <view class="container">//視圖容器 <view bindtap="bindViewTap" class="userinfo">//bindtap為容器綁定點擊觸摸事件,在觸摸離開時觸發(fā)bindViewTap事件處理函數(shù),bindViewTap通過index.js page()設(shè)置添加 <image class="userinfo-avatar" src="{{userInfo.avatarUrl}}" background-size="cover"></image>//大雙括號的變量來自于index.js的data對象解析成對應(yīng)的值,而且是實時的 <text class="userinfo-nickname">{{userInfo.nickName}}</text> </view> <view class="usermotto"> <text class="user-motto">{{motto}}</text> </view> </view>
index.js,與reaact用法幾無二異,換湯不換藥。page()來注冊一個頁面。接受一個 OBJECT 參數(shù),其指定頁面的初始數(shù)據(jù)、生命周期函數(shù)、事件處理函數(shù)等。
var app = getApp() // 獲取入口文件app的應(yīng)用實例 Page({ data: { motto: 'Hello World', userInfo: {} }, //自定義事件處理函數(shù),點擊.userinfo的容易觸發(fā)此函數(shù) bindViewTap: function() { wx.navigateTo({//全局對象wx的跳轉(zhuǎn)頁面方法 url: '../logs/logs' }) }, onLoad: function () {//發(fā)生頁面加載時,自動觸發(fā)該生命周期函數(shù) console.log('onLoad') var that = this //調(diào)用應(yīng)用實例的方法獲取全局?jǐn)?shù)據(jù) app.getUserInfo(function(userInfo){ //更新數(shù)據(jù),頁面自動渲染 that.setData({ userInfo:userInfo }) }) } })
index.wxss文件只渲染當(dāng)前所屬頁面,會覆蓋全局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數(shù)組,遍歷多少次,block塊就會復(fù)制多少次,for-item等同于為<br>遍歷元素起一個變量名,方便引用。<br> <text class="log-item">{{index + 1}}. {{log}}</text> </block> </view>
logs.js 文件
//logs.js var util = require('../../utils/util.js') //util.js相當(dāng)于一個函數(shù)庫,我們可以在這個文件內(nèi)自定義擴(kuò)展和封裝一些常用的函數(shù)和方法 Page({ data: { logs: [] }, onLoad: function () { this.setData({ logs: (wx.getStorageSync('logs') || []).map(function (log) {//通過wx.getStorageSync獲取本地緩存的logs日志數(shù)據(jù) return util.formatTime(new Date(log))//日期格式化 }) }) } })
logs.json文件
{ "navigationBarTitleText": "查看啟動日志" //當(dāng)前頁面配置文件,設(shè)置window當(dāng)前頁面頂部導(dǎo)航欄標(biāo)題等相關(guān)內(nèi)容 }
基本頁面結(jié)構(gòu)和邏輯就這么簡單,暴露給我們的沒有一點令人費解的東西。
小程序還提供了很多官方組件和API等待我們深挖,加油吧,少年!
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,更多相關(guān)內(nèi)容請關(guān)注PHP中文網(wǎng)!
相關(guān)推薦:
微信小程序?qū)崿F(xiàn)拖拽 image 觸摸事件監(jiān)聽
DVA框架統(tǒng)一處理所有頁面的loading狀態(tài)
Atas ialah kandungan terperinci 微信小程序前端源碼的解析. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Portal log masuk untuk versi web Douyin adalah https://www.douyin.com/. Langkah -langkah log masuk termasuk: 1. Buka penyemak imbas; 2. Masukkan URL https://www.douyin.com/; 3. Klik butang "Masuk" dan pilih kaedah log masuk; 4. Masukkan kata laluan akaun; 5. Log masuk lengkap. Versi Web menyediakan fungsi seperti melayari, mencari, interaksi, memuat naik video dan pengurusan laman web peribadi, dan mempunyai kelebihan seperti pengalaman skrin besar, pelbagai tugas, pengurusan akaun mudah dan statistik data.

Komik menyalin tidak diragukan lagi sebagai harta yang tidak dapat dilepaskan. Di sini anda boleh menemui komik bola keranjang dalam pelbagai gaya, dari cerita kompetitif yang bersemangat dan inspirasi untuk komedi harian yang santai dan lucu. Sama ada anda ingin menghidupkan semula klasik atau menemui karya baru, menyalin komik dapat memenuhi keperluan anda. Melalui portal bacaan dalam talian yang disediakan oleh Copy Comics, anda akan mengucapkan selamat tinggal kepada masalah sumber cetak rompak, menikmati pengalaman membaca yang tinggi dan lancar, dan dapat menyokong pengarang komik kegemaran anda dan menyumbang kepada pembangunan komik yang sahih.

Memilih penyemak imbas UC atau penyemak imbas QQ bergantung kepada keperluan anda: 1. Pelayar UC sesuai untuk pengguna yang mengejar fungsi hiburan yang cepat dan kaya; 2. Pelayar QQ sesuai untuk pengguna yang memerlukan kestabilan dan sambungan lancar dengan produk Tencent.

Menggabungkan trend industri terkini dan data penilaian pelbagai dimensi pada tahun 2025, yang berikut adalah cadangan perisian penulisan AI yang komprehensif, yang meliputi senario arus perdana seperti penciptaan umum, penyelidikan akademik, dan pemasaran komersial, sambil mengambil kira perkhidmatan pengoptimuman dan penyetempatan Cina:

Komik yang bagus, platform pengalaman membaca yang mendalam yang didedikasikan untuk mencipta pencinta komik, menyatukan sejumlah besar sumber komik berkualiti tinggi di rumah dan di luar negara. Ia bukan sahaja platform membaca komik, tetapi juga komuniti yang menghubungkan artis komik dan pembaca dan berkongsi budaya komik. Melalui reka bentuk antara muka yang mudah dan intuitif dan fungsi carian yang kuat, NES Comics membolehkan anda dengan mudah mencari karya kegemaran anda dan menikmati pengalaman membaca yang lancar dan selesa. Katakan selamat tinggal kepada operasi yang lama menunggu dan membosankan, masukkan dunia komik yang bagus dengan serta -merta dan mulakan perjalanan komik anda!

Komik Frogman telah menjadi pilihan pertama bagi banyak pencinta komik dengan sumber komik yang kaya dan pelbagai dan pengalaman membaca dalam talian yang mudah dan lancar. Ia seperti kolam yang bersemangat, dengan cerita -cerita segar dan menarik yang sentiasa muncul, menunggu anda menemui dan meneroka. Frog Man Comics meliputi pelbagai subjek, dari pengembaraan yang ghairah hingga cinta manis, dari fantasi dan fiksyen sains untuk penangguhan yang menggembirakan, tidak kira genre yang anda suka, anda dapat mencari karya kegemaran anda di sini. Reka bentuk antara muka yang mudah dan intuitif membolehkan anda dengan mudah memulakan, dengan cepat mencari komik yang anda ingin baca, dan tenggelamkan diri anda dalam dunia komik yang menarik.

Di sini, anda boleh menikmati lautan komik yang luas dan meneroka karya-karya pelbagai tema dan gaya, dari komik lelaki muda yang ghairah hingga komik gadis yang halus dan bergerak, dari komik misteri yang membosankan dan membakar otak untuk komik harian yang santai dan lucu, ada segala-galanya, dan selalu ada yang dapat menyentuh hati anda. Kami bukan sahaja mempunyai sejumlah besar sumber komik yang tulen, tetapi juga sentiasa memperkenalkan dan mengemas kini kerja -kerja terkini untuk memastikan bahawa anda dapat membaca komik kegemaran anda secepat mungkin.

Laman web rasmi terbaru 2025b anhui adalah: https://www.marketwebb.co/zh-cn/join?ref=507720986& ;type=wenzi; Binance Exchange adalah pertukaran cryptocurrency global yang melayani 180 negara dan wilayah termasuk Amerika Utara, Eropah, Taiwan, Timur Tengah, Hong Kong, dan Malaysia. Ia menyediakan lebih daripada 600 kriptografi dan mempunyai 270 juta pengguna berdaftar di seluruh dunia.
