当前位置: 首页 > article >正文

微信小程序中 “页面” 和 “非页面” 的区别

微信小程序中 “页面” 和 “非页面” 的区别,并用表格进行对比。

核心概念:

  • 页面 (Page): 页面是微信小程序中用户可以直接交互的视图层,也是小程序的基本组成部分。每个页面都有自己的 WXML 结构、WXSS 样式和 JavaScript 逻辑。
  • 非页面 (Non-Page): 非页面泛指小程序中不直接构成用户界面的其他类型的文件,它们通常用于封装公共逻辑、数据模型、网络请求等。

页面 (Page) 与 非页面 (Non-Page) 的区别:

特性页面 (Page)非页面 (Non-Page)
主要作用构成用户界面的基本单元,是用户可以直接看到的交互界面。用于封装公共逻辑、数据模型、网络请求等,不直接展示用户界面。
文件类型主要包括: .wxml (页面结构), .wxss (页面样式), .js (页面逻辑), json (页面配置)通常是 .js 文件,但也可能包括 .json 配置文件,但不能直接配置样式。
目录结构通常放置在 pages 目录下的子目录中,每个页面都有自己的目录,包含 WXML、WXSS、JS 和 JSON 文件。可以放置在 utilsapicomponents 等目录中,用于组织代码逻辑。
生命周期有自己的完整生命周期,例如 onLoadonShowonReadyonHideonUnload 等,用于管理页面状态。没有页面生命周期,其内部的函数或逻辑会在其他地方被调用。
数据绑定可以使用微信小程序的数据绑定语法 ({{ ... }}),将数据渲染到 WXML 页面结构中,并实现动态更新。不直接参与页面渲染,而是通过 JavaScript 代码或其他组件间接影响页面显示。
事件处理可以定义事件处理函数,响应用户的交互行为,例如点击、滑动、输入等。通常不直接处理用户的交互事件,而是提供一些功能函数或逻辑,供页面或其他组件调用。
组件可以使用小程序组件,构建更复杂的界面元素。通常不会直接使用小程序组件,而是用于封装一些基础的服务方法或者逻辑。
路由跳转可以使用 wx.navigateTowx.redirectTowx.switchTab 等 API 进行页面跳转。不直接参与页面路由跳转,而是供其他页面调用。
wx.getApp()可以使用 wx.getApp()getApp() 函数获取到小程序的实例对象, 并可以使用 this 直接访问组件的数据或者函数。如果在 Page 或者 Component 中, 可以使用 this 访问 Page 或者 Component 的数据和方法。 在非页面文件中使用 wx.getApp() 会因为上下文的问题,导致获取不到小程序实例。
作用域拥有自己的独立作用域,可以使用 this 关键字访问当前页面的数据和方法, 可以访问 Page 的生命周期函数。作用域取决于定义的位置,不能使用 this 访问页面和组件的数据或者方法。

详细解释:

  • 页面 (Page):
    • 用户直接交互: 页面是用户直接看到的,并且可以在其上进行操作的界面。例如,首页、列表页、详情页、设置页等都是页面。
    • 页面结构: 使用 .wxml 文件描述页面的结构。
    • 页面样式: 使用 .wxss 文件描述页面的样式。
    • 页面逻辑: 使用 .js 文件编写页面的逻辑,例如处理用户的交互行为、发送网络请求、更新页面数据等。
    • 页面配置: 使用 .json 文件描述页面的配置信息,例如导航栏样式、页面背景色等。
  • 非页面 (Non-Page):
    • 封装通用逻辑: 非页面通常用于封装一些通用的 JavaScript 代码或逻辑,例如:
      • 网络请求封装
      • 数据模型定义
      • 工具函数封装
      • 自定义组件的实现
    • 没有界面: 非页面不会直接展示用户界面,而是作为辅助模块被页面或其他组件使用。
    • 模块化: 非页面可以帮助您模块化代码,提高代码的可复用性和可维护性。

总结:

  • 页面是用户界面的组成部分, 它包含了结构、样式和逻辑,并可以直接展示给用户。
  • 非页面是用于封装代码逻辑的模块, 它们不会直接展示用户界面,而是辅助页面完成功能。

理解页面和非页面的区别,对于开发出结构清晰、易于维护的微信小程序至关重要。

在这里插入图片描述


http://www.kler.cn/a/467421.html

相关文章:

  • 算法:两个升序单链表的合并
  • 1-markdown转网页样式页面 --[制作网页模板] 【测试代码下载】
  • 【JVM】总结篇-类的加载篇之 类的加载器 和ClassLoader分析
  • Oracle 11g rac + Dataguard 环境调整 redo log 大小
  • Speech Recognition vs. Voice Recognition | 语音识别工作原理 | 模型训练 | 应用
  • 安卓漏洞学习(十七):维京海盗-Strandhogg漏洞
  • mysql入门篇
  • 网络安全抓包
  • 【制造业】大数据一站式解决方案
  • SQL 分析函数与聚合函数的组合应用
  • Spring Boot - 日志功能深度解析与实践指南
  • 代理IP助力VR行业革新,小派科技引领技术潮流
  • C语言(自定义)函数
  • LeetCode 力扣 热题 100道(二十八)矩阵置零(C++)
  • ImportError: /lib/x86_64-linux-gnu/libc.so.6: version `GLIBC_2.32‘ not found
  • L27.【LeetCode笔记】2 的幂(五种解法)
  • 1.C语言教程:历史、特点、版本与入门示例
  • Tableau数据可视化与仪表盘搭建-安装教程
  • 探寻AI Agent:开启知识图谱自动生成新篇章(17/30)
  • SpringBoot入门之创建一个Hello World项目
  • Tesseract5.4.0自定义LSTM训练
  • 互联网直播点播平台EasyDSS无人机视频推拉流技术实现工地远程监控巡检直播
  • CAN201 Introduction to Networking(计算机网络)Pt.4 链路层
  • Nginx:负载均衡
  • Qt6.8.1 Mingw13.1 编译opencv4.10时cannot convert ‘char*‘ to ‘LPWSTR
  • Day27:for-in语句