【小程序全面解析】生命周期、常用组件,代码示例和使用场景

本文涉及的产品
可观测监控 Prometheus 版,每月50GB免费额度
可观测可视化 Grafana 版,10个用户账号 1个月
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
简介: 该文章全面介绍了小程序的生命周期、常用基础组件以及使用场景,并提供了相应的代码示例。读者可以了解小程序的生命周期函数及其执行时机,以及学习如何使用常用基础组件构建小程序页面。此外,文章还列举了各种使用场景,帮助读者更好地理解如何应用小程序开发。如果您是小程序开发的初学者或需要了解小程序的基础知识,该文章将为您提供全面的帮助和指导。

上一篇文章我们实现了小程序用户增删改查功能,在这篇文章中我们详细介绍一下小程序生命周期,以及小程序基础组件。
在这里插入图片描述

前言

小程序是一种轻量级的应用程序,具有独立的生命周期和基础组件。以下是小程序的生命周期介绍、常用基础组件介绍、代码示例和使用场景。

小程序生命周期

小程序生命周期指的是小程序从创建到销毁期间经历的一系列阶段和事件。了解小程序生命周期可以帮助开发者在适当的时机执行相应的代码逻辑。

小程序的生命周期可以分为两部分:应用生命周期和页面生命周期。

应用生命周期

应用生命周期指的是小程序从启动到销毁期间经历的一系列阶段和事件。以下是小程序应用生命周期的各个阶段:

onLaunch: 当小程序初始化完成时触发,全局只触发一次;
onShow: 当小程序启动或从后台进入前台显示时触发;
onHide: 当小程序从前台进入后台时触发;
onError: 当小程序发生脚本错误或 API 调用失败时触发;
onPageNotFound: 当小程序页面找不到时触发。

以下是小程序应用生命周期的代码示例:

App({
   
  onLaunch: function () {
   
    console.log('小程序初始化完成')
  },
  onShow: function () {
   
    console.log('小程序启动或从后台进入前台显示')
  },
  onHide: function () {
   
    console.log('小程序从前台进入后台')
  },
  onError: function (msg) {
   
    console.log('小程序发生错误:', msg)
  },
  onPageNotFound: function (options) {
   
    console.log('小程序页面找不到:', options)
  }
})

页面生命周期

页面生命周期指的是小程序页面从创建到销毁期间经历的一系列阶段和事件。以下是小程序页面生命周期的各个阶段:

onLoad: 当页面加载时触发;
onShow: 当页面显示时触发;
onReady: 当页面初次渲染完成时触发;
onHide: 当页面隐藏时触发;
onUnload: 当页面卸载时触发。

以下是小程序页面生命周期的代码示例:

Page({
   
  onLoad: function (options) {
   
    console.log('页面加载')
  },
  onShow: function () {
   
    console.log('页面显示')
  },
  onReady: function () {
   
    console.log('页面初次渲染完成')
  },
  onHide: function () {
   
    console.log('页面隐藏')
  },
  onUnload: function () {
   
    console.log('页面卸载')
  }
})

使用场景

小程序生命周期的使用场景比较广泛,例如:

onLoad:用于获取页面参数,初始化数据等;
onShow:用于监听页面显示事件,执行一些初始化操作;
onHide:用于监听页面隐藏事件,暂停页面动画和音乐等操作;
onUnload:用于监听页面卸载事件,清除页面相关的定时器和数据等。

开发者可以根据具体的业务需求,在生命周期函数中编写相应的代码逻辑。

小程序的基础组件

小程序的基础组件是小程序提供的常用组件,包括视图容器、表单组件、媒体组件等。开发者可以通过使用这些基础组件来快速构建小程序页面。

以下是小程序常用的基础组件介绍、代码示例及使用场景:

视图容器

视图容器是小程序中最常用的组件之一,包括 view、scroll-view、swiper 等。

view:视图容器,类似于 HTML 中的 div,用于组合其他组件和文本。
scroll-view:可滚动视图容器,可以垂直和水平滚动,用于显示长列表和横向滑动的内容。
swiper:轮播图组件,用于展示多张图片或卡片式内容。
以下是 view 组件的代码示例:

<view class="container">
  <view class="title">这是一个标题</view>
  <view class="content">这是内容区域</view>
</view>

使用场景:用于组合其他组件和文本,构建页面的基本结构。

表单组件

表单组件用于收集用户输入的数据,包括 input、textarea、radio、checkbox 等。

input:文本输入框,用于输入单行文本。
textarea:多行文本输入框,用于输入多行文本。
radio:单选框,用于选择一个选项。
checkbox:多选框,用于选择多个选项。
以下是 input 组件的代码示例:

<form bindsubmit="onSubmit">
  <view class="form-item">
    <view class="form-label">用户名:</view>
    <input name="username" placeholder="请输入用户名" />
  </view>
  <view class="form-item">
    <view class="form-label">密码:</view>
    <input name="password" type="password" placeholder="请输入密码" />
  </view>
  <button formType="submit">提交</button>
</form>

使用场景:用于收集用户输入的数据,例如登录、注册、搜索等场景。

媒体组件

媒体组件用于播放音频、视频和图片,包括 image、audio、video 等。

image:图片组件,用于显示图片。
audio:音频组件,用于播放音频。
video:视频组件,用于播放视频。
以下是 image 组件的代码示例:

<view class="container">
  <image src="{
    {imageUrl}}" mode="aspectFit"></image>
</view>

使用场景:用于展示图片、播放音频和视频等媒体内容。

总结

本篇文章主要介绍如何从零开始开发微信小程序,并以实现用户增删改查功能为例,详细讲解了小程序的目录结构、项目创建、编码等方面。通过本文的学习,读者可以了解到微信小程序开发的基本流程和常见操作,为深入学习和实践提供了基础。

希望本文对初学者有所帮助,如果有任何问题或建议,欢迎留言讨论。


✍创作不易,求关注😄,点赞👍,收藏⭐️

相关文章
|
1月前
|
小程序 数据可视化 JavaScript
微信小程序:轻松实现时间轴组件
本文介绍了如何在微信小程序中实现一个可视化时间轴组件。该组件适用于展示用户资金流动、投资结算等时间节点,帮助用户直观了解资金去向。时间轴支持自定义节点形状、显示序号、倒序排列等功能,并通过插槽灵活定义动态内容。文中详细介绍了组件的设计与使用方法,以及如何结合动态 slot 实现自定义操作。该组件为展示用户资金信息提供了美观、易用的解决方案。
59 1
微信小程序:轻松实现时间轴组件
|
21天前
|
前端开发 JavaScript 开发者
揭秘前端高手的秘密武器:深度解析递归组件与动态组件的奥妙,让你代码效率翻倍!
【10月更文挑战第23天】在Web开发中,组件化已成为主流。本文深入探讨了递归组件与动态组件的概念、应用及实现方式。递归组件通过在组件内部调用自身,适用于处理层级结构数据,如菜单和树形控件。动态组件则根据数据变化动态切换组件显示,适用于不同业务逻辑下的组件展示。通过示例,展示了这两种组件的实现方法及其在实际开发中的应用价值。
28 1
|
1月前
|
存储 JavaScript 前端开发
Vue3权限控制全攻略:路由与组件层面的用户角色与权限管理方法深度解析
Vue3权限控制全攻略:路由与组件层面的用户角色与权限管理方法深度解析
111 2
|
1月前
|
小程序
微信小程序动态tabBar实现:基于自定义组件,灵活支持不同用户角色与超过5个tab自由组合(更新版)
微信小程序动态tabBar实现:基于自定义组件,灵活支持不同用户角色与超过5个tab自由组合(更新版)
407 1
|
1月前
|
机器学习/深度学习 编解码 算法
深入解析MaxFrame:关键技术组件及其对视频体验的影响
【10月更文挑战第12天】随着流媒体服务和高清视频内容的普及,用户对于视频质量的要求越来越高。为了满足这些需求,许多技术被开发出来以提升视频播放的质量。其中,MaxFrame是一种旨在通过一系列先进的图像处理算法来优化视频帧的技术。本文将深入探讨构成MaxFrame的核心组件,包括运动估计、超分辨率重建以及时间插值算法,并讨论这些技术如何协同工作以改善视频播放效果。
38 1
|
1月前
|
小程序 搜索推荐 API
微信小程序:自定义关注公众号组件样式
尽管关注公众号组件的样式固定且不可修改,但产品经理的需求却需要个性化的定制。在这种情况下,我们需要寻找解决方案,以满足这些特殊需求,尽管这可能有点棘手。
60 0
微信小程序:自定义关注公众号组件样式
|
1月前
|
开发框架 小程序 JavaScript
小程序代码丢失!反编译找回
小程序源代码的容易获取问题确实存在一些潜在的安全隐患。然而,现在的小程序开发框架采用像 Babel 这样的打包工具,将 JavaScript 逻辑代码混合在一个文件中并进行转编译,使其变得难以理解。
38 0
小程序代码丢失!反编译找回
|
1月前
|
小程序 前端开发 JavaScript
微信小程序图表制作利器:ECharts组件的使用与技巧
微信小程序图表制作利器:ECharts组件的使用与技巧
55 1
|
17天前
|
机器学习/深度学习 自然语言处理 数据管理
GraphRAG核心组件解析:图结构与检索增强生成
【10月更文挑战第28天】在当今数据科学领域,自然语言处理(NLP)和图数据管理技术的发展日新月异。GraphRAG(Graph Retrieval-Augmented Generation)作为一种结合了图结构和检索增强生成的创新方法,已经在多个应用场景中展现出巨大的潜力。作为一名数据科学家,我对GraphRAG的核心组件进行了深入研究,并在此分享我的理解和实践经验。
38 0
|
1月前
|
移动开发 小程序 数据可视化
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
216 3

推荐镜像

更多