【微信小程序】-- 自定义组件 - 纯数据字段 & 组件的生命周期(三十六)

简介: 【微信小程序】-- 自定义组件 - 纯数据字段 & 组件的生命周期(三十六)



一、纯数据字段

  前面通过案例完整学习了自定义组件中数据监听器的用法,以及监听指定数据和所有数据的方法。接下来就来讲解一下另外一个自定义组件 - 纯数据字段 & 组件的生命周期。上个周末连着两天没写偷懒了,一天不学习,罪恶感嘎嘎上升呀。话不多说,让我们原文再续,书接上回吧。

1、什么是纯数据字段

  纯数据字段顾名思义指的是那些不用于界面渲染的 data 字段。应用场景:例如有些情况下,某些 data 中的字段既不会展示在界面上,也不会传递给其他组件,仅仅在当前组件内部使用。带有这种特性的 data 字段适合被设置为纯数据字段。

  比如前面学习过数据监听器案例中,像 r, g, b 这三个值是没有必要渲染到页面上的,所以这三个适合当纯数据字段。

  设置为纯数据字段有助于提升页面更新的性能。

2、基本语法

  在 Component 构造器的 options 节点中,指定 pureDataPattern 为一个 正则表达式,字段名符合这个正则表达式的字段将成为纯数据字段,示例代码如下:

Component({
  options: {
    // 指定所以 _开头的数据字段为纯数据字段
    pureDataPattern: /^_/
  },
  /**
   * 组件的初始数据
   */
  data: {
    _rgb: {
      r: 0, 
      g: 0, 
      b: 0
    },
    // 根据 rgb 对象的三个属性,动态计算 fullColor 的值
    fullColor: '0, 0, 0' 
  },
})

  注意:纯数据字段只能用于页面逻辑的处理,不能用于页面渲染。

3、使用纯数据字段改造数据监听器案例

  了解纯数据字段基本用法之后,接下来就通过改造数据监听器案例来巩固一下吧,具体代码如下所示:

test3.js

Component({
  options: {
    // 指定所以 _开头的数据字段为纯数据字段
    pureDataPattern: /^_/
  },
  /**
   * 组件的初始数据
   */
  data: {
    //将 rgb 改造为纯数据字段
    _rgb: {
      r: 0, 
      g: 0, 
      b: 0
    },
    // 根据 rgb 对象的三个属性,动态计算 fullColor 的值
    fullColor: '0, 0, 0' 
  },
})

  改造完成之后,编译运行发现运行结果跟之前是一样的,如下图所示:

二、组件的生命周期

  组件的生命周期,指的是组件自身的一些函数,这些函数在特殊的时间点或遇到一些特殊的框架事件时被自动触发。

1、组件全部的生命周期函数

  小程序组件可用的全部生命周期如下表所示:

生命周期 参数 描述 最低版本
created 在组件实例刚刚被创建时执行 1.6.3
attached 在组件实例进入页面节点树时执行 1.6.3
ready 在组件在视图层布局完成后执行 1.6.3
moved 在组件实例被移动到节点树另一个位置时执行 1.6.3
detached 在组件实例被从页面节点树移除时执行 1.6.3
error Object Error 每当组件方法抛出错误时执行 2.4.1

2、组件主要的生命周期函数

  在小程序组件中,最重要的生命周期函数有 3 个,分别是 created、attached、detached,包含一个组件实例生命流程的最主要时间点。。它们各自的特点如下:

  • 组件实例刚刚被创建好时, created 生命周期被触发。此时,组件数据 this.data 就是在 Component 构造器中定义的数据 data
  • 此时还不能调用 setData
  • 通常情况下,这个生命周期只应该用于给组件 this 添加一些自定义属性字段。
  • 在组件完全初始化完毕、进入页面节点树后, attached 生命周期被触发。
  • 此时, this.data 已被初始化为组件的当前值。
  • 这个生命周期很有用,绝大多数初始化工作可以在这个时机进行(例如发请求获取初始数据)。
  • 在组件离开页面节点树后, detached 生命周期被触发。
  • 退出一个页面时,如果组件还在页面节点树中,则 detached 会被触发。
  • 此时适合做一些清理性质的工作。

3、定义生命周期方法

  在小程序组件中,生命周期函数可以直接定义在 Component 构造器的第一级参数中,可以在 lifetimes 字段内进行声明(这是推荐的方式,其优先级最高)。具体代码如下:

Component({
  lifetimes: {
    attached: function() {
      // 在组件实例进入页面节点树时执行
    },
    detached: function() {
      // 在组件实例被从页面节点树移除时执行
    },
  },
  // 以下是旧式的定义方式,可以保持对 <2.2.3 版本基础库的兼容
  attached: function() {
    // 在组件实例进入页面节点树时执行
  },
  detached: function() {
    // 在组件实例被从页面节点树移除时执行
  },
  // ...
})

  在 behaviors 中也可以编写生命周期方法,同时不会与其他 behaviors 中的同名生命周期相互覆盖。但要注意,如果一个组件多次直接或间接引用同一个 behavior ,这个 behavior 中的生命周期函数在一个执行时机内只会执行一次。

  behaviors 后续会学习到,这里先了解即可。

  • 旧式的定义方式

test3.js

Component({
  created(){
    console.dir("created");
  },
  attached(){
    console.dir("attached");
  },
   /**
   * 组件的初始数据
   */
  data: {...}
})

  可以来看一下运行效果:

  • 新的定义方式(推荐)

test3.js

Component({
  created(){
    console.dir("created");
  },
  attached(){
    console.dir("attached");
  },
  lifetimes:{
    created(){
      console.dir("created-------");
    },
    attached(){
      console.dir("attached------");
    },
  },
   /**
   * 组件的初始数据
   */
  data: {...}
})

  注意,如果新的跟旧的在一起,新的就会覆盖旧的定义方式,在实际开发过程中是不推荐用旧的定义方式,可以来看一下运行效果:


总结

  感谢观看,这里就是自定义组件 - 纯数据字段 & 组件的生命周期的介绍使用,如果觉得有帮助,请给文章点个赞吧,让更多的人看到。🌹 🌹 🌹

  也欢迎你,关注我。👍 👍 👍

  原创不易,还希望各位大佬支持一下,你们的点赞、收藏和留言对我真的很重要!!!💕 💕 💕 最后,本文仍有许多不足之处,欢迎各位认真读完文章的小伙伴们随时私信交流、批评指正!下期再见。

相关文章
|
1月前
|
小程序 数据可视化 JavaScript
微信小程序:轻松实现时间轴组件
本文介绍了如何在微信小程序中实现一个可视化时间轴组件。该组件适用于展示用户资金流动、投资结算等时间节点,帮助用户直观了解资金去向。时间轴支持自定义节点形状、显示序号、倒序排列等功能,并通过插槽灵活定义动态内容。文中详细介绍了组件的设计与使用方法,以及如何结合动态 slot 实现自定义操作。该组件为展示用户资金信息提供了美观、易用的解决方案。
60 1
微信小程序:轻松实现时间轴组件
|
1月前
|
小程序
微信小程序动态tabBar实现:基于自定义组件,灵活支持不同用户角色与超过5个tab自由组合(更新版)
微信小程序动态tabBar实现:基于自定义组件,灵活支持不同用户角色与超过5个tab自由组合(更新版)
418 1
|
1月前
|
小程序 搜索推荐 API
微信小程序:自定义关注公众号组件样式
尽管关注公众号组件的样式固定且不可修改,但产品经理的需求却需要个性化的定制。在这种情况下,我们需要寻找解决方案,以满足这些特殊需求,尽管这可能有点棘手。
60 0
微信小程序:自定义关注公众号组件样式
|
1月前
|
小程序 前端开发 JavaScript
微信小程序图表制作利器:ECharts组件的使用与技巧
微信小程序图表制作利器:ECharts组件的使用与技巧
60 1
|
1月前
|
移动开发 小程序 数据可视化
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
222 3
|
1月前
|
小程序 API
微信小程序更新提醒uniapp
在小程序开发中,版本更新至关重要。本方案利用 `uni-app` 的 `uni.getUpdateManager()` API 在启动时检测版本更新,提示用户并提供立即更新选项,自动下载更新内容,并在更新完成后重启小程序以应用新版本。适用于微信小程序,确保用户始终使用最新版本。以下是实现步骤: ### 实现步骤 1. **创建更新方法**:在 `App.vue` 中创建 `updateApp` 方法用于检查小程序是否有新版本。 2. **测试**:添加编译模式并选择成功状态进行模拟测试。
49 0
微信小程序更新提醒uniapp
|
3月前
|
小程序 前端开发 Java
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目
JavaDog Chat v1.0.0 是一款基于 SpringBoot、MybatisPlus 和 uniapp 的简易聊天软件,兼容 H5、小程序和 APP,提供丰富的注释和简洁代码,适合初学者。主要功能包括登录注册、消息发送、好友管理及群组交流。
106 0
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目
|
3月前
|
小程序 前端开发 JavaScript
【项目实战】SpringBoot+uniapp+uview2打造一个企业黑红名单吐槽小程序
【避坑宝】是一款企业黑红名单吐槽小程序,旨在帮助打工人群体辨别企业优劣。该平台采用SpringBoot+MybatisPlus+uniapp+uview2等技术栈构建,具备丰富的注释与简洁的代码结构,非常适合实战练习与学习。通过小程序搜索“避坑宝”即可体验。
103 0
【项目实战】SpringBoot+uniapp+uview2打造一个企业黑红名单吐槽小程序
|
3月前
|
存储 小程序 JavaScript
|
4月前
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp的汉服交易小程序的详细设计和实现(源码+lw+部署文档+讲解等)
基于SpringBoot+Vue+uniapp的汉服交易小程序的详细设计和实现(源码+lw+部署文档+讲解等)
62 7

热门文章

最新文章

下一篇
无影云桌面