一级片大奶子_色又黄又爽18禁免费视频_热久久久久久久_久久久精品一区二区_日韩av不卡在线播放_精品国内自产拍在线观看视频

注冊

微信小程序教程入門篇【4】,MINA框架的視圖層邏輯層

2017-12-20
導讀:本帖最后由 狂兔科技 于 2016-11-1 18:14 編輯 1. 開篇導言 本節目標:通過 上一節 的講解,相信大家對小程序框架MINA的目錄結構和配置有了一定的了解。接下來將會講解視圖層,邏輯層及...

1. 開篇導言    
  • 本節目標:通過上一節的講解,相信大家對小程序框架MINA的目錄結構和配置有了一定的了解。接下來將會講解視圖層,邏輯層及其之間的交互。
  • 目標用戶:無編程經驗,但對微信小程序感興趣的同學。
  • 學習目標:了解MINA框架的視圖層(View),邏輯層(App Service),及其之間的交互。
  • 案例分析:helloworld小程序。
  • 代碼下載
  • 傳送門:

上一篇:微信小程序教程-入門篇【3】   
下一篇:
微信小程序教程-入門篇【5】   

  • 備注:有編程經驗或看過微信官網簡易教程的同學,請酌情略過該章節。

2. MINA結構基礎
從某種程度來來講,我們可以把MINA的結構簡化如下圖:
微信小程序教程入門篇【4】,MINA框架的視圖層邏輯層

view模塊:負責UI顯示。它由開發者編寫的wxml,wxss及微信提供的相關組件來組成。
service模塊:負責應用的后臺邏輯,它由小程序的 js 代碼以及微信提供的相關輔助模塊組成。
其中view模塊由view thread進行驅動,service模塊則由AppService Thread進行驅動。我們說view模塊和service模塊之間的交互,其實指的是線程間的交互。
一個小程序只有一個 service 進程,它在程序生命周期內后臺運行。當小程序進入后臺一定時間,或者系統資源占用過高,才會被真正的銷毀。

3. 案例展示
微信小程序教程入門篇【4】,MINA框架的視圖層邏輯層
上圖為該項目的兩個頁面。左面:主頁面。右面:logs頁面。
下面將分為三部分對helloworld進行講解:啟動流程,主頁面,logs頁面。

4. 啟動流程
微信小程序教程入門篇【4】,MINA框架的視圖層邏輯層

  • 邏輯入口:app.js

app.js的代碼如下:
  1. //app.js
  2.  
  3. //1. App()函數用來注冊一個小程序。接受一個object參數,其指定小程序的生命周期函數等。
  4. App({
  5.  
  6.   //2. 生命周期函數--監聽小程序初始化,當小程序初始化完成時,會觸發onLaunch(全局只觸發一次)  
  7.   onLaunch: function () {
  8.     //調用API從本地緩存中獲取數據
  9.     var logs = wx.getStorageSync('logs') || []
  10.     logs.unshift(Date.now())
  11.     wx.setStorageSync('logs', logs)
  12.   },
  13.  
  14.   //3. 成員方法:獲取用戶數據。
  15.   getUserInfo:function(cb){
  16.     var that = this
  17.     if(this.globalData.userInfo){
  18.       typeof cb == "function" && cb(this.globalData.userInfo)
  19.     }else{
  20.       //調用登錄接口
  21.       wx.login({
  22.         success: function () {
  23.           wx.getUserInfo({
  24.             success: function (res) {
  25.               that.globalData.userInfo = res.userInfo
  26.               typeof cb == "function" && cb(that.globalData.userInfo)
  27.             }
  28.           })
  29.         }
  30.       })
  31.     }
  32.   },
  33.  
  34.   //4. 全局數據
  35.   globalData:{
  36.     userInfo:null
  37.   }
  38. })
  39.  
  40. //注意:App()必須在app.js中注冊,且不能注冊多個。
  41. //     不要在定義于App()內的函數中調用getApp(),使用this就可以拿到app實例。
  42. //     不要在onLaunch的時候調用getCurrentPage(),此時page還沒有生成。
復制代碼

上面的代碼文件說明了app.js文件的用處:注冊App()。這里面包含兩部分。
其一:生命周期函數的定義(onLaunch/onShow/onHide)。
其二:自定義函數,通常用于操作全局數據或微信提供的用戶等業務邏輯數據。
           全局數據。


  • 啟動后的主頁面:app.json

啟動后的主頁面,根據app.json中【pages】中的部分來決定。準備的來說,誰在上面則主頁面是誰。在該項目中,代碼如下:
  1. "pages":[
  2.     "pages/index/index",
  3.     "pages/logs/logs"            
  4.   ],
復制代碼
如果我們把index和logs更換位置,則主頁面則由上圖中的左圖更換為右圖。代碼如下:
  1. "pages":[
  2.     "pages/logs/logs",
  3.     "pages/index/index"               
  4.   ],
復制代碼


5. 主頁面
微信小程序教程入門篇【4】,MINA框架的視圖層邏輯層

上圖描述了啟動后,進入主頁面,小程序的調用流程。


  • 文件層

找尋在路徑【"pages/index/index"】中,后綴為.json,.js,.wxml,.wxss的文件,并進行整合。

  • 代碼層

對于路由后的主頁面,調用onLoad,onShow。該項目中代目如下:
  1. //index.js
  2.  
  3. //1. 獲取應用實例
  4. var app = getApp()
  5.  
  6. //2. Page() 函數用來注冊一個頁面。接受一個 object 參數,其指定頁面的初始數據、生命周期函數、事件處理函數等。
  7. Page({
  8.  
  9.   //3. 頁面的初始數據
  10.   data: {
  11.     motto: 'Hello World',
  12.     userInfo: {}
  13.   },
  14.  
  15.   //4. 事件處理函數,當用戶點擊該組件的時候,調用該事件處理函數。跳轉到logs頁面。
  16.   bindViewTap: function() {
  17.     wx.navigateTo({
  18.       url: '../logs/logs'
  19.     })
  20.   },
  21.  
  22.   //5. 頁面加載,一個頁面只會調用一次.
  23.   onLoad: function () {
  24.     console.log('onLoad')
  25.     var that = this
  26.     //調用應用實例的方法獲取全局數據
  27.     app.getUserInfo(function(userInfo){
  28.       //更新數據
  29.       that.setData({
  30.         userInfo:userInfo
  31.       })
  32.     })
  33.   }
  34.  
  35. })
  36.  
復制代碼

視圖層和邏輯層的交互是通過事件機制來實現的,上面代碼【4】所示為邏輯層的處理邏輯。事件代碼在視圖層如下所示:
  1. <view  bindtap="bindViewTap" class="userinfo">
  2.     <image class="userinfo-avatar" src="{{userInfo.avatarUrl}}" background-size="cover"></image>
  3.     <text class="userinfo-nickname">{{userInfo.nickName}}</text>
  4.   </view>
復制代碼

如上所示,從coding層面上講,事件機制由兩部分組成。其一在page相關的wxml文件中。其二在.js文件中,定義相應的處理函數,并通過函數名進行關聯識別。

6. logs頁面
  • logs頁面分析

logs.js代碼如下:
  1. //logs.js
  2.  
  3. //1. 加載模塊
  4. var util = require('../../utils/util.js')
  5.  
  6. Page({
  7.  
  8.   //2. Page() 函數用來注冊一個頁面。接受一個 object 參數,其指定頁面的初始數據、生命周期函數、事件處理函數等。
  9.   data: {
  10.     logs: []
  11.   },
  12.  
  13.   //3. 頁面加載,一個頁面只會調用一次.
  14.   onLoad: function () {
  15.     this.setData({
  16.       logs: (wx.getStorageSync('logs') || []).map(function (log) {
  17.         return util.formatTime(new Date(log))
  18.       })
  19.     })
  20.   }
  21.   
  22. })
  23.  
復制代碼
logs.wxml如下:
  1. <!--logs.wxml-->
  2. <view class="container log-list">
  3.  
  4.   <!-- wx:for 在組件上使用wx:for控制屬性綁定一個數組,即可使用數組中各項的數據重復渲染該組件。-->
  5.   <!-- block wx:for 渲染一個包含多節點的結構塊。-->  
  6.   <!-- 用 wx:for-item 可以指定數組當前元素的變量名。-->
  7.   <block wx:for="{{logs}}" wx:for-item="log">
  8.   
  9.     <text class="log-item">{{index + 1}}. {{log}}</text>
  10.   </block>
  11. </view>
  12.  
復制代碼

  • 主頁面和logs頁面之間的跳轉

微信小程序教程入門篇【4】,MINA框架的視圖層邏輯層

7. 小結

知識點:了解MINA框架的視圖層(View),邏輯層(App Service),及其之間的交互。
              了解事件的基本使用方式。
              了解界面之間的跳轉方式及棧空間。

8. 預告

了解并使用微信開發工具的調試功能。
重磅推薦:小程序開店目錄

第一部分:小商店是什么

第二部分:如何開通一個小商店

第三部分:如何登錄小商店

第四部分:開店任務常見問題

第五部分:小商店可以賣什么

第六部分:HiShop小程序特色功能

第七部分:小程序直播

第八部分:小程序收貨/物流

第九部分:小程序怎么結算

第十部分:小程序客服

第十一部分:電商創業

第十二部分:小程序游戲開發

主站蜘蛛池模板: 国产麻豆另类=aV|极品久久久久|桃花色综合影院|国产夜恋视频在线观看|美女=av免费在线观看|久久久国产一区二区三区四区 | 亚洲v天堂v手机在线|午夜成年视频|FREEZEFR=aME丰满少妇|日本天堂网站|亚洲热综合|欧美V=a亚洲V=a在线观看日本 | WWW免费视频在线观看播放|欧美日本一道本一区二区|999在线精品视频|国产十日韩十欧美|天堂网中文字幕在线观看|日韩一二三四 | 亚洲精品成人|疯狂做受XXXX欧美老人|亚洲精品视频在线观看免费|亚洲一区二区三区在线播放|在线日韩欧美|东京热无码人妻系列综合网站 | 广东少妇大战黑人34厘米视频|日韩午夜在线|国产=aⅴ激情无码久久久无码|精品人妻无码一区二区三区色欲|日本阿v天堂|亚洲视频在线播放 | 亚洲无人区码二码三码区别|亚洲无砖无线码|老师的朋友5在线|国产精品美女黄网|欧美一级做=a爰片免费视频|www.高潮原创=av | #NAME?|www.夜夜骑|亚洲人成网站精品片在线观看|视频在线观看入口黄最新永久免费国产|日本免费一级|巨大垂乳日本熟妇 | 神马国产精品|国产丝袜91久久久久久久久久久|亚洲人成在线播放网站|国产8区|四虎永久在线精品免费网址|近伦毛片中文字幕免费的 | xxxx高清|亚洲日本乱码在线观看|日三级另类|久久久一|www.国产com|欧美不卡一区二区三区四区 | 超清纯白嫩大学生无码网站|97精品人人做人人爱|最新啪啪网站|国产老熟女网站|国产精久久久久久久|久久九九久久 | 欧美在线视频三区|国产中文原创|日本午夜免费福利视频|国产色综合色产在线视频|综合国产精品|猫咪成人在线观看 | 国产日本无码视频韩国网站写真|国产又色又爽又刺激在线播放|亚洲精品456在线播放牛牛影院|久久久亚洲国产|午夜视频成人|国产伦孑沙发午休精品 | 国产免费=ab|视频精品在线观看|国产小视频毛片|高潮好爽视频在线观看|欧美一区二区大片|三级黄片毛片 | 女女同性=aV片在线播放免费|91久久香蕉囯产熟女线看|在线观看国产日韩亚洲中|97se国产在线公开视频|日本欧美视频|国产成人短视频在线观看 | 欧美特一级片|午夜肉伦伦影院无码|色18亚洲美女|亚洲成人黄网|山村少妇肉系列1一7|天堂8在线新版官网 | 一本到亚洲网|99久久精品国产欧美主题曲|973理论片235影院|国产一区二区高清在线|亚州国产视频|国产精品一卡二卡三卡 | 粗壮挺进邻居人妻无码|久久天天拍|#NAME?|日本亚洲黄色|久久精品国产只有精品96|日本成年人免费网站 | 台湾久久网|99久久精品免费看国产四区|亚洲一区二区三区在线视频观看|一区二区三区四区在线免费视频|红桃视频二区|国产久艹视频 | 日本欧美在线观看视频|国产免费观看黄=aV片|男女猛烈无遮挡免费视频|久久久久久18|四虎最新紧急更新地址|久久丝袜 | 亚洲精品网站在线观看|国产精品美女久久福利网站|久久xxxx|亚洲精品精品|国产激情99|国产高清无码日韩一区 | 蜜臀=aⅴ精品一区二区三区|5c5c5c5c|午夜免费|四虎影视最新免费版|色噜噜狠狠狠狠色综合久|精品服丝袜无码视频一区|国产一区日韩一区 | 荡乳欲妇在线观看|小次郎=av收藏家|国产亚洲日韩在线=a不卡|亚洲天堂久久久久久久|国产精品福利在线播放|国产成人无码=a片免费 | 男同免费|久久久久久草莓香蕉步兵|亚洲女女女同性VIDEO|免费的=av不用播放器的|黄频网站在线观看|久久久88 | 美女高潮无遮挡免费视频|x8x8拨牐拨牐x8免费视频8文字|97青青|91麻豆精品国产自产在线|亚洲伦理精品|69=av在线看 | 国产一区二区三区怡红院|91自拍.com|国91精品久久久久9999不卡|久久精品国产精品亚洲艾草网|九色精品|亚洲一区二区综合 | 亚洲欧美日韩精品综久久久久久|99热这里只有精品99|国产成人综合精品|无码人妻一区二区三区免费N鬼逝|无码人妻=aⅤ一区二区三区麻豆|69xx×在线观看 | 完美世界免费观看完整在线观看|日韩黄色一级大片|粉嫩=aV久久一区二区三区王玥|三级全黄的视频在线观看|91亚洲精品丁香在线观看|色香蕉视频 | 久久婷婷国产综合尤物精品|日日日噜噜噜|日本韩国欧美一级片|欧美一级二级在线观看|最新无码人妻在线不卡|国产精品入口夜色视频大尺度 | 日韩=av在线中文|三年片在线观看大全中国|日韩视频在线观看中文字幕|91在线看免费|免费人成在线观看视频无码|一个人看的视频www在线观看 | 天天射影院|车子做=a爱片在线观看HD|人成午夜免费视频无码|四虎影视免费|中文字幕日本二区|中文字幕久久精品一区二区三区 | 免费无码黄网站在线看|九九在线精品视频|h黄动漫免费网站|成人小说亚洲一区二区三区|极品老师腿张开粉嫩小泬|婷婷开心中文字幕 | 7788.毛片|手机看成人片|日日夜夜操婷婷|亚洲日本中文字幕天天更新|免费成视频|gogogo免费观看视频高清 | 免费无遮挡无码视频网站|欧美人与ZOXXXX视频|色香婷婷综合激情网|亚洲综合久久无码色噜噜|欧美xxxx黑人又粗又长密月|国产精品九九久久久久久久 | 国产精品成人**免费视频|亚洲免费在线播放视频|国产激情一级毛片久久久|99久免费精品视频在线观78|97dyy97影院理论片在线|日韩成人免费视频 | 国产成人精品高清在线观看99|亚州综合网|亚洲视频观看|新国产美女遭强高潮免费|奇米777在线观看|蜜臀=avwww国产天堂 | 国产波霸爆乳一区二区|尤物在线网址|黑人干白妞|精品一卡2卡三卡4卡免费视频|亚洲欧美VR色区|国产性=av | 干亚洲美女|亚洲视频精选|91国自视频|亚洲一级影片|韩国三级在线中文字幕无码|xxx黄色片 | 午夜免费啪视频在线体验区|亚洲成本人片无码免费|亚洲=av成人无码网站色优|自拍偷拍第1页|久久精品性一区区裸体艺术|久久久久亚洲=av成人动图 | 日韩小视频网站hq|免费观看视频的网站视频|色情无码WWW视频无码区|国产精=av|国产人妻无码一区二区三区不卡|色我综合 | 亚洲wwww|给个毛片网站|欧美日韩伦理在线|日本妈妈黄色片|日韩毛片在线观看|久久精品观看 | 亚洲第一区在线观看|性欧美大战久久久久久久安居码|天天干夜夜春夜夜爽|色视频2|成人爽=a毛片免费啪啪红桃视频|极品少妇小泬50PTHEPON 91成人毛片|#NAME?|亚洲视频1区2区3区4区|国产思思99re99在线观看|激情春色|国产一区二区三区四区在线观看 |