当前位置:   article > 正文

自定义组件-组件的生命周期_自定义组件的生命周期函数

自定义组件的生命周期函数

自定义组件-组件的生命周期

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

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

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

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

在小程序组件中,最重要的生命中远期函数有3个,分别是createdattacheddetached。它们各自的特点

如下:

  1. 组件实例刚被创建好的时候,created生命周期函数会被触发

    • 此时还不能调用setData
    • 通常在这个生命函数中,只应该用于给组件的this添加一些自定义的属性字段
  2. 在组件完全初始化完毕、进入页面节点树后,attached生命周期函数会被触发

    • 此时,this.data已被初始化完毕
    • 这个声明周期很有用,绝大多数初始化的工作可以在这个实际进行(例如发请求获取初始数据)
  3. 在组件离开页面节点树后,detached生命周期函数会被触发

    • 退出一个页面时,会触发页面内每个自定义组件的detached生命周期函数
    • 此时适合做一些清理性质的工作

3.lifetimes节点

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

Component({
	// 推荐用法
	lifetimes:{
		attched(){ }, // 在组件实例进入页面节点树时执行
		detached(){ }, // 在组件实例被从页面节点树移除时执行
	},
	// 以下是旧式的定义方式
	attched(){ }, // 在组件实例进入页面节点树时执行
	detached(){ }, // 在组件实例被从页面节点树移除时执行
})
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

自定义组件-组件所在页面的生命周期

1.什么是组件所在页面的生命周期

有时,自定义组件的行为依赖于页面状态的变化,此时就需要用到组件所在页面的生命周期

例如,每当触发页面的show生命周期函数的时候,我们希望能够重新生成一个随机的RGB颜色值。

在自定义组件中,组件所在页面的生命周期函数有如下3个,分别是:

生命周期函数参数描述
show组件所在的页面被展示时执行
hide组件所在的页面被隐藏时执行
resizeObject Size组件所在的页面尺寸变化时执行

2.pageLifetimes节点

组件所在页面的生命周期函数,需要定义在pageLifetimes节点中,示例代码如下:

Component({
  pageLifetimes:{
  	show:function(){},  // 页面被展示
  	hide:function(){},  // 页面被隐藏
  	resize:function(size){ } // 页面尺寸变化
  }
})
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

3.生成随机的RGB颜色

代码示例:

// components/test3/test3.js
Component({
    /**
     * 组件的属性列表
     */
    properties: {

    },

    /**
     * 组件的初始数据
     */
    data: {
        rgb:{
            r:0,
            g:0,
            b:0
        },
        fullColor:'0,0,0'
    },
    
    /**
     * 组件的方法列表
     */
    methods: {
        _randomColor(){
            this.setData({
                rgb:{
                    r:Math.floor(Math.random()*256),
                    g:Math.floor(Math.random()*256),
                    b:Math.floor(Math.random()*256)
                }
            })
        }
    },
    pageLifetimes:{
        show(){
            this._randomColor()
        }
    }
})

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Monodyee/article/detail/88224
推荐阅读
相关标签
  

闽ICP备14008679号