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

news2024/10/2 3:34:22

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 文件中的代码如下

const formatTime = date => {
  const year = date.getFullYear()
  const month = date.getMonth() + 1
  const day = date.getDate()
  const hour = date.getHours()
  const minute = date.getMinutes()
  const second = date.getSeconds()

  return `${[year, month, day].map(formatNumber).join('/')} ${[hour, minute, second].map(formatNumber).join(':')}`
}

const formatNumber = n => {
  n = n.toString()
  return n[1] ? n : `0${n}`
}

module.exports = {
  formatTime
}


       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 ! 工程中的此文件内容如下:
{ 
 "pages":[ 
  "pages/index/index", 
  "pages/logs/logs" 
 ], 
 "window":{ 
  "backgroundTextStyle":"light", 
  "navigationBarBackgroundColor": "#fff", 
  "navigationBarTitleText": "Weixin", 
  "navigationBarTextStyle":"black" 
 }, 
 "style": "v2", 
 "sitemapLocation": "sitemap.json" 
}
{ 
 "pages":[ //配置页面路由列表 
  "pages/index/index", 
  "pages/logs/logs" 
 ], 
 "window":{ //配置应用窗口表现 
  "backgroundTextStyle":"light", //页面背景色样式 
  "navigationBarBackgroundColor": "#fff", //导航栏背景色 
  "navigationBarTitleText": "Weixin", //导航栏标题 
  "navigationBarTextStyle":"black" //导航栏文字颜色 
 }, 
 "style": "v2", //应用样式,版本 2 
 "sitemapLocation": "sitemap.json" //sitemap 文件位置 
} 

说明:

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 选项用来对底部或顶部
的标签栏进行配置,顶部的标签栏效果。
例代码如下:
"tabBar": {
 "list": [{
 "pagePath": "pages/index/index",
 "text": "主页"
 },{
 "pagePath": "pages/logs/logs",
 "text": "日志"
 }],
 "position":"top",
 "color": "#ff0000",
 "backgroundColor": "#0000ff",
 "borderStyle": "white"
 }

"tabBar": { //底部导航栏配置
 "list": [{ //导航项列表
 "pagePath": "pages/index/index", //导航到页面路径
 "text": "主页" //导航项文字
 },{
"pagePath": "pages/logs/logs",
 "text": "日志"
 }],
 "position":"top", //导航栏位置,这里是顶部
 "color": "#FF0000
", //文字颜色
 "backgroundColor": "#0000FF
", //导航栏背景色
 "borderStyle": "white" //导航栏边框色
}
 
说明:
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 文件中默认生成的代码如下:
// app.js
App({
 onLaunch() {
 // 展示本地存储能力
 const logs = wx.getStorageSync('logs') || []
 logs.unshift(Date.now())
 wx.setStorageSync('logs', logs)
 // 登录
 wx.login({
 success: res => {
 // 収送 res.code 到后台换取 openId, sessionKey, unionId
 }
 })
 },
 globalData: {
 userInfo: null
 }
})
// app.js
App({ 
onLaunch() { 
 // 展示本地存储能力
 const logs = wx.getStorageSync('logs') || [] //获取本地存储的 logs,如果没有默认为
空数组
 logs.unshift(Date.now()) //往数组头部添加当前时间
 wx.setStorageSync('logs', logs) //将 logs 存储到本地
 // 登录
 wx.login({ 
 success: res => { 
 // 収送 res.code 到后台换取 openId, sessionKey, unionId 
 } 
 }) 
}, 
globalData: { 
 userInfo: null 
} 
})
说明:
      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 文件中的内容,如下所示:
// logs.js
const util = require('../../utils/util.js')
Page({
 // data 选项提供页面渲染所需要的数据
 data: {
 logs: []
 },
 // 页面加载的生命周期方法
 onLoad() {
 this.setData({
 logs: (wx.getStorageSync('logs') || []).map(log => {
 return {
 date: util.formatTime(new Date(log)),
 timeStamp: log
 }
 })
 })
 }
})
/ logs.js 
const util = require('../../utils/util.js') 
Page({ 
// data 选项提供页面渲染所需要的数据 
data: { 
 logs: [] 
}, 
// 页面加载的生命周期方法
onLoad() {
 this.setData({ 
 logs: (wx.getStorageSync('logs') || []).map(log => { 
 // 返回包含 date 和 timeStamp 的对象 
 return { 
date: util.formatTime(new Date(log)), // 调用 util 中的 formatTime 格式化时
间戳为日期字符串
 timeStamp: log 
 } 
 }) 
 })
} 
})
说明:
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
选项是一个生命周期回调,当页面加载时会调用此方法,一些页面的加载逻辑可以在这个回调中
实现。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1472125.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

rhel8配置bond遇到的问题汇总

操作环境信息 配置bond mode=4 两块网卡的配置信息 bond卡的配置信息(标红是后来加上的) 遇到的问题 rhel8 使用NetworkManage 管理网络,而不使用network,经常用到的命令是nmcli 拉起bond0后,因为没有获取到ip地址,每隔一段时间就会将网卡down掉,出现nic link is down …

代码随想录算法训练营第四三天 | 最后一块石头的重量 II、目标和、一和零

目录 最后一块石头的重量 II目标和一和零 LeetCode 1049. 最后一块石头的重量 II LeetCode 494. 目标和 LeetCode 474.一和零 最后一块石头的重量 II class Solution {// dp[j] 容量为j 的背包,最多可以背最大重量为dp[j]。// dp[j] Math.max(dp[j], dp[j - sto…

zabbix3.4.6 源码安装

Step1: 下载 https://www.zabbix.com/download 选中一下。download Zabbix Sources PackageReleaseDateRelease NotesZabbix ManualDownloadZabbix 3.4Server, Proxy, Agent, GUI3.4.615 January, 2018 Download step2 :拷贝在redhat 6.3_X86_86(192…

基于huggingface加载openai/clip-vit-large-patch14-336视觉模型demo

文章目录 引言一、模型加载二、huggingface梯度更新使用三、图像处理四、模型推理五、整体代码总结 引言 本文介绍如何使用huggingface加载视觉模型openai/clip-vit-large-patch14-336,我之所以记录此方法源于现有大模型基本采用huggingface库来加载视觉模型和大语…

【生成式AI】ChatGPT 原理解析(2/3)- 预训练 Pre-train

Hung-yi Lee 课件整理 预训练得到的模型我们叫自监督学习模型(Self-supervised Learning),也叫基石模型(foundation modle)。 文章目录 机器是怎么学习的ChatGPT里面的监督学习GPT-2GPT-3和GPT-3.5GPTChatGPT支持多语言…

nginx(二)

nginx的验证模块 输入用户名和密码 第一步先下载httpd 这个安装包 第二步编辑子配置文件 然后去网页访问192.168.68.3/admin/ 连接之后,会出现404,404出现是因为没给网页写页面 如果要写页面,则在/opt/html,建立一个admin&#x…

算法沉淀——动态规划之路径问题(leetcode真题剖析)

算法沉淀——动态规划之路径问题 01.不同路径02.不同路径 II03.珠宝的最高价值04.下降路径最小和05.最小路径和06.地下城游戏 01.不同路径 题目链接:https://leetcode.cn/problems/unique-paths/ 一个机器人位于一个 m x n 网格的左上角 (起始点在下图…

探索C语言位段的秘密

位段 1. 什么是位段2. 位段的内存分配3. 位段的跨平台问题4. 位段的应用4. 使用位段的注意事项 1. 什么是位段 我们使用结构体实现位段,位段的声明和结构体是类似的,有两个不同: 位段的成员必须是int,unsigned int,或…

IO进程线程作业day7

信号灯集共享内存 自定义头文件 #ifndef SEM_H_ #define SEM_H_ //创建信号灯集, int creat_t(int number); //申请释放资源 int P(int semid,int semno); //申请释放资源 int V(int semid,int semno); //删除信号灯集 int del(int semid); #endif信号灯集函数集合 #include…

多维时序 | Matlab实现GRU-MATT门控循环单元融合多头注意力多变量时间序列预测模型

多维时序 | Matlab实现GRU-MATT门控循环单元融合多头注意力多变量时间序列预测模型 目录 多维时序 | Matlab实现GRU-MATT门控循环单元融合多头注意力多变量时间序列预测模型预测效果基本介绍程序设计参考资料 预测效果 基本介绍 1.多维时序 | Matlab实现GRU-MATT门控循环单元融…

wcf 简单实践 数据绑定 数据更新ui

1.概要 2.代码 2.1 xaml <Window x:Class"WpfApp3.MainWindow"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d"http://schemas.microsoft.com/expr…

《数据治理简易速速上手小册》第2章 数据治理框架的建立(2024 最新版)

文章目录 2.1 确立数据治理目标2.1.1 基础知识2.1.2 重点案例&#xff1a;提升零售业数据质量2.1.3 拓展案例 1&#xff1a;银行的数据安全加强2.1.4 拓展案例 2&#xff1a;医疗机构的合规性数据报告 2.2 数据治理框架的关键要素2.2.1 基础知识2.2.2 重点案例&#xff1a;制药…

VM-UNet:视觉Mamba UNet用来医学图像分割 论文及代码解读

VM-UNet 期刊分析摘要贡献方法整体框架1. Vision Mamba UNet (VM-UNet)2. VSS block3. Loss function 实验1.对比实验2.消融实验 可借鉴参考代码使用 期刊分析 期刊名&#xff1a; Arxiv 论文主页&#xff1a; VM-UNet 代码&#xff1a; Code 摘要 在医学图像分割领域&#x…

JANGOW: 1.0.1

kali:192.168.223.128 主机发现 nmap -sP 192.168.223.0/24 端口扫描 nmap -p- 192.168.223.154 开启了21 80端口 web看一下&#xff0c;有个busque.php参数是buscar,但是不知道输入什么&#xff0c;尝试文件包含失败 扫描目录 dirsearch -u http://192.168.223.154 dirse…

mysql 分表实战

本文主要介绍基于range分区的相关 1、业务需求&#xff0c;每日160w数据&#xff0c;每月2000w;解决大表数据读写性能问题。 2、数据库mysql 8.0.34&#xff0c;默认innerDB;mysql自带的逻辑分表 3、分表的目的:解决大表性能差&#xff0c;小表缩小查询单位的特点(其实优化的精…

人事|人事管理系统|基于Springboot的人事管理系统设计与实现(源码+数据库+文档)

人事管理系统目录 目录 基于Springboot的人事管理系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、管理员登录 2、员工管理 3、公告信息管理 4、公告类型管理 5、培训管理 6、培训类型管理 四、数据库设计 1、实体ER图 五、核心代码 六、论文参考 七、…

2024年环境安全科学、材料工程与制造国际学术会议(ESSMEM2024)

【EI检索】2024年环境安全科学、材料工程与制造国际学术会议&#xff08;ESSMEM2024) 会议简介 我们很高兴邀请您参加将在三亚举行的2024年环境安全科学、材料工程和制造国际学术会议&#xff08;ESSMEM 2024&#xff09;。 ESSMEM2024将汇集世界各国和地区的研究人员&…

CrackRTF1

由此可知为六位密码且<100000自动退出 发现是哈希加密&#xff0c;经过网上查找后了解到 0x8004u 为 SHA1 加密&#xff0c;故从网上寻找脚本并进行爆破 密码为123321 找到一个取巧的网站 MD5免费在线解密破解_MD5在线加密-SOMD5 Flag{N0_M0re_Free_Bugs}

Mysql索引讲解及创建

索引介绍 1.什么是索引&#xff1f; 索引是存储引擎中一种数据结构&#xff0c;或者说数据的组织方式&#xff0c;又称之为键key&#xff0c;是存储引擎用于快速找到记录的 一种数据结构。 为数据建立索引就好比是为书建目录&#xff0c;或者说是为字典创建音序表&#xff0c;…

视频号视频下载教程:如何把微信视频号的视频下载下来

视频号下载相信不少人都多少有一些了解&#xff0c;但今天我们就来细说一下关于视频号视频下载的相关疑问&#xff0c;以及大家经常会问到底如何把微信视频号的视频下载下来&#xff1f; 视频号视频下载教程 视频号链接提取器详细使用指南&#xff0c;教你轻松下载号视频&…