• 第 2 章 微信小程序的构成 (代码导读)断更,后续继续更新


    2.1 小程序项目的基本结构

    Hello World!程序.mp4

    文泉云盘 -- 图书二维码资源管理系统兆泰源二维码管理系统icon-default.png?t=N7T8https://www.wqyunpan.com/resourceDetail.html?id=284928&openId=oUgl9wdyNYHu9EcAe-GEwbQdZilY&qrcodeId=242916&sign=c2lnbm1PUmNxSndPWGFOckZ4aVUtMTcwODk1Mjk1MTQ5Mw==@c2lnblhtclRUSmZDWWp4QUVjYmctMTcwODk1Mjk1MTQ5Mw==

    2.1.1 项目目录结构

    之前小北创建的 Hello World! 项目的目录结构:


           从中可以看到,工程根目录中有两个文件夹page所示。和 utils 以及一些独立文件。先来介绍各个独立文件的用途。

    • .eslintrc.js是ESLint 配置文件,小程序默认使用ESLint 进行代码检查,在开发中一般无须修改这个文件。
    • appjs 文件可以理解为是小程序的入口文件,在这个文件中进行小程序应用实例的注册,整个小程序只有一个应用实例,此实例是全局共享的。
    • app.json 是当前小程序项目的全局配置文件,在其中进行页面路由、窗口标题等全局信息的配置。
    • app.wxss 是当前小程序项目中编写的公共样式表,这里面配置的样式在所有组件中都可以直接应用。
    • project.config.ison 是工程配置文件,在这个文件中可以对当前小程序工作做一些个性化的配置,如界面颜色、编译规则等。
    • sitemap.json是一个配置文件,用来配置小程序页面是否允许被微信搜索。

    下面,再来看一下工程根目录下的两个文件夹。
    utils 文件夹用来存放一些提供工具支持的 JS 文件,默认生成的 utiljs 文件中的代码如下

    1. const formatTime = date => {
    2. const year = date.getFullYear()
    3. const month = date.getMonth() + 1
    4. const day = date.getDate()
    5. const hour = date.getHours()
    6. const minute = date.getMinutes()
    7. const second = date.getSeconds()
    8. return `${[year, month, day].map(formatNumber).join('/')} ${[hour, minute, second].map(formatNumber).join(':')}`
    9. }
    10. const formatNumber = n => {
    11. n = n.toString()
    12. return n[1] ? n : `0${n}`
    13. }
    14. module.exports = {
    15. formatTime
    16. }


           util.is 中实际上提供了一个获取格式化后的当前日期时间的方法。

           pages文件夹用来存放所有页面,在小程序开发中,一个完整的页面由JS、WXML、WXSS和JSON这4类文件组成,因此在pages 文件夹下,每一个子文件夹即表示一个小程序页面,在预览 Hello World!项目时,会看到首页上会展示当前登录用户的微信头像,这个页面其实就是工程中的index页面,如果点击用户头像,小程序会跳转到一个显示启动记录的页面,此页面就是项目中的 logs 页面。

    2.1.2 小程序全局配置文件

           在小程序项目中, JSON 文件通常用来设置配置选项。每个小程序工程下会有一个全局配置
    文件,即 app.json ,小程序中的每一个页面也会有一个配置文件。
    Hello World!项目中的 logs 页面:
          先来关注一下 app.json 这个文件, Hello World ! 工程中的此文件内容如下:
    1. {
    2. "pages":[
    3. "pages/index/index",
    4. "pages/logs/logs"
    5. ],
    6. "window":{
    7. "backgroundTextStyle":"light",
    8. "navigationBarBackgroundColor": "#fff",
    9. "navigationBarTitleText": "Weixin",
    10. "navigationBarTextStyle":"black"
    11. },
    12. "style": "v2",
    13. "sitemapLocation": "sitemap.json"
    14. }
    15. {
    16. "pages":[ //配置页面路由列表
    17. "pages/index/index",
    18. "pages/logs/logs"
    19. ],
    20. "window":{ //配置应用窗口表现
    21. "backgroundTextStyle":"light", //页面背景色样式
    22. "navigationBarBackgroundColor": "#fff", //导航栏背景色
    23. "navigationBarTitleText": "Weixin", //导航栏标题
    24. "navigationBarTextStyle":"black" //导航栏文字颜色
    25. },
    26. "style": "v2", //应用样式,版本 2
    27. "sitemapLocation": "sitemap.json" //sitemap 文件位置
    28. }

    说明:

    1. pages 数组配置了应用的页面路由 , 分别为 index 首页和 logs 日志页面。
    2. window 对象配置了应用窗口的表现 , 包括背景色样式、导航栏背景色、导航栏标题、导航栏文字颜色等。
    3. style 属性配置了应用样式的版本 , 这里是版本 2
    4. sitemapLocation 属性配置了 sitemap 文件的位置 , 这里为 sitemap.json

          其中,pages 字段用来配置程序中所有的页面路径,只要是应用内使用到的页面,都需要在 这里进行配置。window 字段用来对窗口的表现形式进行配置,包括背景色、标题文字、标题颜色 等。style 字段用来配置 UI 页面的风格。sitemapLocation 用来设置项目中 sitemap 文件的位置。

    1.entryPagePath
          这个字段用来设置小程序启动时的默认页面,如果不配置,小程序在启动时将默认选择配置在 pages 列表中的第一个页面作为默认页面。以 HelloWorld 项目为例,我们也可以配置小程序在启动时直接展示日志页面,示例代码如下:
          "entryPagePath":"pages/logs/logs"
    2.pages
           这个配置项不再做过多的介绍,其用来指定小程序由哪些页面组成,需要配置为一个列表列表中的每一项对应一个页面的路径,文件名无须带后缀,框架会自动寻找对应的 WXML、JSJSON 和 WXSS 文件。

    3.window
           window 选项用于对小程序的窗口表现进行全局设置,其可以配置的选项很多,

    如表所示:

      4. tabBar
         如果小程序有多个功能模块,可以采用多 tab 的模式来构建。 tabBar 选项用来对底部或顶部
    的标签栏进行配置,顶部的标签栏效果。
    例代码如下:
    1. "tabBar": {
    2. "list": [{
    3. "pagePath": "pages/index/index",
    4. "text": "主页"
    5. },{
    6. "pagePath": "pages/logs/logs",
    7. "text": "日志"
    8. }],
    9. "position":"top",
    10. "color": "#ff0000",
    11. "backgroundColor": "#0000ff",
    12. "borderStyle": "white"
    13. }
    14. "tabBar": { //底部导航栏配置
    15. "list": [{ //导航项列表
    16. "pagePath": "pages/index/index", //导航到页面路径
    17. "text": "主页" //导航项文字
    18. },{
    19. "pagePath": "pages/logs/logs",
    20. "text": "日志"
    21. }],
    22. "position":"top", //导航栏位置,这里是顶部
    23. "color": "#FF0000
    24. ", //文字颜色
    25. "backgroundColor": "#0000FF
    26. ", //导航栏背景色
    27. "borderStyle": "white" //导航栏边框色
    28. }
     
    说明:
    1. tabBar 对象配置了底部导航栏的属性。
    2. list 数组配置了多个导航项 , 每个导航项包含 pagePath text, 分别表示导航路径和显示文字。
    3. position 属性配置了导航栏的位置 , 这里是顶部。
    4. color 属性配置了导航项文字的颜色 , 这里是红色。
    5. backgroundColor 属性配置了导航栏的背景色 , 这里是蓝色。
    6. borderStyle 属性配置了导航栏边框的颜色 , 这里是白色。

    2.2 小程序的开发架构

    2.2.1 注册小程序

           每个小程序应用都需要在 app.js 文件中先注册一个应用实例。整个小程序只有一个应用实
    例,这个实例是全局共享的,可以通过如下方法来获取此应用实例:
            const appInstance = getApp()
          这段代码的作用是获取小程序的全局应用实例。
    getApp() 是微信小程序提供的一个全局 API,用于获取全局唯一的 App 实例。
          const appInstance = getApp() 的作用是 :
          1. 使用 getApp() 获取到小程序的全局应用实例。
          2. 将这个全局应用实例赋值给一个常量 appInstance
          3. 之 后就可以通过 appInstance 来访问全局的应用实例 , 幵调用应用实例上的属性、方法等。
          4. 加上 const 是为了声明 appInstance 是一个常量 , 刜始化后不可再修改挃向 , 防止错误地覆盖了全局
    应用实例。
           这样获取全局的应用实例后 , 就可以在仸意页面中轻松访问共享的实例和数据 , 实现页面间通信等功能。
           比如可以在 appInstance 上维护一些全局数据 , 仸意页面可以通过 appInstance.globalData 来读取
    和修改。
           所以这是一个小程序开収中获取全局变量的常用模式。
    在之前的 HelloWorld 项目中,app.js 文件中默认生成的代码如下:
    1. // app.js
    2. App({
    3. onLaunch() {
    4. // 展示本地存储能力
    5. const logs = wx.getStorageSync('logs') || []
    6. logs.unshift(Date.now())
    7. wx.setStorageSync('logs', logs)
    8. // 登录
    9. wx.login({
    10. success: res => {
    11. // 収送 res.code 到后台换取 openId, sessionKey, unionId
    12. }
    13. })
    14. },
    15. globalData: {
    16. userInfo: null
    17. }
    18. })
    19. // app.js
    20. App({
    21. onLaunch() {
    22. // 展示本地存储能力
    23. const logs = wx.getStorageSync('logs') || [] //获取本地存储的 logs,如果没有默认为
    24. 空数组
    25. logs.unshift(Date.now()) //往数组头部添加当前时间
    26. wx.setStorageSync('logs', logs) //将 logs 存储到本地
    27. // 登录
    28. wx.login({
    29. success: res => {
    30. // 収送 res.code 到后台换取 openId, sessionKey, unionId
    31. }
    32. })
    33. },
    34. globalData: {
    35. userInfo: null
    36. }
    37. })
    说明:
          1. // app.js 注释表明这是 app.js 文件。
          2. // 展示本地存储能力 注释表明以下代码是为了展示本地存储的能力。
           3. // 获取本地存储的 logs, 如果没有默认为空数组 注释解释了 wx.getStorageSync('logs') 的意图 与默认值。
           4. // 往数组头部添加当前时间 注释说明了 logs.unshift(Date.now()) 的功能。
           5. // logs 存储到本地 注释说明了 wx.setStorageSync('logs', logs) 的作用。
           6. // 登录 注释表示以下代码是为了实现登录功能。
           7. // 发 res.code 到后台换取 openId, sessionKey, unionid。
            App()方法用来注册应用实例,需要注意,此方法必须在 app.js 文件中调用,且只能调用一
    次。此方法中可以传入一个配置对象,在上面的示例代码中,传入的配置对象配置了 onLaunch 和 globalData 两个选项,onLaunch 是小程序的生命周期回调,小程序初始化时会被调用。globalData 用来配置小程序中所需要使用的全局数据。

    2.2.2 小程序中页面的注册

           与应用的注册类似,每个页面的 JS 文件中也要进行页面的注册 使用 Page() 方法来进行页
    面注册,可以先看一下 HelloWorld 工程中 logs.js 文件中的内容,如下所示:
    1. // logs.js
    2. const util = require('../../utils/util.js')
    3. Page({
    4. // data 选项提供页面渲染所需要的数据
    5. data: {
    6. logs: []
    7. },
    8. // 页面加载的生命周期方法
    9. onLoad() {
    10. this.setData({
    11. logs: (wx.getStorageSync('logs') || []).map(log => {
    12. return {
    13. date: util.formatTime(new Date(log)),
    14. timeStamp: log
    15. }
    16. })
    17. })
    18. }
    19. })
    20. / logs.js
    21. const util = require('../../utils/util.js')
    22. Page({
    23. // data 选项提供页面渲染所需要的数据
    24. data: {
    25. logs: []
    26. },
    27. // 页面加载的生命周期方法
    28. onLoad() {
    29. this.setData({
    30. logs: (wx.getStorageSync('logs') || []).map(log => {
    31. // 返回包含 date 和 timeStamp 的对象
    32. return {
    33. date: util.formatTime(new Date(log)), // 调用 util 中的 formatTime 格式化时
    34. 间戳为日期字符串
    35. timeStamp: log
    36. }
    37. })
    38. })
    39. }
    40. })
    说明:
    1. // logs.js 注释表示这是 logs.js 文件。
    2. // data 选项提供页面渲染所需要的数据
           注释说明 data 对象存放页面渲染所需数据。
    3. // 页面加载的生命周期方法
           注释表示 onLoad 方法是页面的生命周期方法 , 在页面加载时触収。
    4. // 返回包含 date timeStamp 的对象
            注释说明 map 方法返回的对象包含 date timeStamp 属性。
    5. // 调用 util 中的 formatTime 格式化时间戳为日期字符串
           注释说明 date 属性由 util.formatTime 方法根据 timeStamp 生成。
    6. // timeStamp
           该属性的意思很明显 , 为时间戳。
           之所以选择 logs.js 文件来做参考,是因为相比 index.js,日志页面要简单很多。Page()方法中
    也需要传入一个配置对象,如上代码所示,data 选项用来配置当前页面所要使用的数据。onLoad
    选项是一个生命周期回调,当页面加载时会调用此方法,一些页面的加载逻辑可以在这个回调中
    实现。
  • 相关阅读:
    leetcode-303-区域和检索 - 数组不可变
    每次打开百度太麻烦?用程序直接打开网页 Python实现百度划词搜索功能(获取剪切板数据)
    虚拟机识别
    PMP 11.27 考试倒计时6天!
    支持券商的量化接口怎么使用python来执行交易过程?
    荐书 | 《考试脑科学》:这样学习才能事半功倍
    计算机组成原理百道必考大总结(上)
    补题2.0
    【单片机基础小知识-如何通过指针来读写寄存器】
    mysql冷拷贝大表
  • 原文地址:https://blog.csdn.net/Zhiyilang/article/details/136307728