千家信息网

MINA框架的视图层和逻辑层实例分析

发表于:2024-11-19 作者:千家信息网编辑
千家信息网最后更新 2024年11月19日,本篇内容主要讲解"MINA框架的视图层和逻辑层实例分析",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"MINA框架的视图层和逻辑层实例分析"吧!1. 开篇导
千家信息网最后更新 2024年11月19日MINA框架的视图层和逻辑层实例分析

本篇内容主要讲解"MINA框架的视图层和逻辑层实例分析",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"MINA框架的视图层和逻辑层实例分析"吧!


1. 开篇导言

  • 目标用户:无编程经验,但对微信小程序感兴趣的同学。

  • 学习目标:了解MINA框架的视图层(View),逻辑层(App Service),及其之间的交互。

  • 案例分析:helloworld小程序。

2. MINA结构基础

view模块:负责UI显示。它由开发者编写的wxml,wxss及微信提供的相关组件来组成。
service模块:负责应用的后台逻辑,它由小程序的 js 代码以及微信提供的相关辅助模块组成。
其中view模块由view thread进行驱动,service模块则由AppService Thread进行驱动。我们说view模块和service模块之间的交互,其实指的是线程间的交互。
一个小程序只有一个 service 进程,它在程序生命周期内后台运行。当小程序进入后台一定时间,或者系统资源占用过高,才会被真正的销毁。

3. 案例展示

上图为该项目的两个页面。左面:主页面。右面:logs页面。
下面将分为三部分对helloworld进行讲解:启动流程,主页面,logs页面。

4. 启动流程

  • 逻辑入口:app.js


app.js的代码如下:

  1. //app.js

  2. //1. App()函数用来注册一个小程序。接受一个object参数,其指定小程序的生命周期函数等。

  3. App({

  4. //2. 生命周期函数--监听小程序初始化,当小程序初始化完成时,会触发onLaunch(全局只触发一次)

  5. onLaunch: function () {

  6. //调用API从本地缓存中获取数据

  7. var logs = wx.getStorageSync('logs') || []

  8. logs.unshift(Date.now())

  9. wx.setStorageSync('logs', logs)

  10. },

  11. //3. 成员方法:获取用户数据。

  12. getUserInfo:function(cb){

  13. var that = this

  14. if(this.globalData.userInfo){

  15. typeof cb == "function" && cb(this.globalData.userInfo)

  16. }else{

  17. //调用登录接口

  18. wx.login({

  19. success: function () {

  20. wx.getUserInfo({

  21. success: function (res) {

  22. that.globalData.userInfo = res.userInfo

  23. typeof cb == "function" && cb(that.globalData.userInfo)

  24. }

  25. })

  26. }

  27. })

  28. }

  29. },

  30. //4. 全局数据

  31. globalData:{

  32. userInfo:null

  33. }

  34. })

  35. //注意:App()必须在app.js中注册,且不能注册多个。

  36. // 不要在定义于App()内的函数中调用getApp(),使用this就可以拿到app实例。

  37. // 不要在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. 主页面


上图描述了启动后,进入主页面,小程序的调用流程。

  • 文件层


找寻在路径【"pages/index/index"】中,后缀为.json,.js,.wxml,.wxss的文件,并进行整合。

  • 代码层


对于路由后的主页面,调用onLoad,onShow。该项目中代目如下:

  1. //index.js

  2. //1. 获取应用实例

  3. var app = getApp()

  4. //2. Page() 函数用来注册一个页面。接受一个 object 参数,其指定页面的初始数据、生命周期函数、事件处理函数等。

  5. Page({

  6. //3. 页面的初始数据

  7. data: {

  8. motto: 'Hello World',

  9. userInfo: {}

  10. },

  11. //4. 事件处理函数,当用户点击该组件的时候,调用该事件处理函数。跳转到logs页面。

  12. bindViewTap: function() {

  13. wx.navigateTo({

  14. url: '../logs/logs'

  15. })

  16. },

  17. //5. 页面加载,一个页面只会调用一次.

  18. onLoad: function () {

  19. console.log('onLoad')

  20. var that = this

  21. //调用应用实例的方法获取全局数据

  22. app.getUserInfo(function(userInfo){

  23. //更新数据

  24. that.setData({

  25. userInfo:userInfo

  26. })

  27. })

  28. }

  29. })

复制代码


视图层和逻辑层的交互是通过事件机制来实现的,上面代码【4】所示为逻辑层的处理逻辑。事件代码在视图层如下所示:

  1. {{userInfo.nickName}}

复制代码


如上所示,从coding层面上讲,事件机制由两部分组成。其一在page相关的wxml文件中。其二在.js文件中,定义相应的处理函数,并通过函数名进行关联识别。

6. logs页面

  • logs页面分析


logs.js代码如下:

  1. //logs.js

  2. //1. 加载模块

  3. var util = require('../../utils/util.js')

  4. Page({

  5. //2. Page() 函数用来注册一个页面。接受一个 object 参数,其指定页面的初始数据、生命周期函数、事件处理函数等。

  6. data: {

  7. logs: []

  8. },

  9. //3. 页面加载,一个页面只会调用一次.

  10. onLoad: function () {

  11. this.setData({

  12. logs: (wx.getStorageSync('logs') || []).map(function (log) {

  13. return util.formatTime(new Date(log))

  14. })

  15. })

  16. }

  17. })

logs.wxml如下:

  1. {{index + 1}}. {{log}}

到此,相信大家对"MINA框架的视图层和逻辑层实例分析"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

0