微信小程序组件所在页面的生命周期

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

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

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

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

二 pageLifetimes 节点

组件所在页面的生命周期函数,需要定义在 pageLifetimes 节点中。

Component({

  pageLifetimes: {

    show() { // 页面被展示时执行

      console.log('show')

      this._randomColor()

    },

    hide() { // 页面被隐藏时执行

      console.log('hide')

    },

    resize() { // 页面尺寸变化时执行

      console.log('resize')

    }

  }

})

三 小案例——生成随机的 RGB 颜色值

Component({

  methods:{

    // 生成随机 RGB 颜色的方法。非事件处理函数建议以 _ 开头

    _randomColor() {

      this.setData({ // 为 data 里面的 _egb 纯数据字段重新赋值

        _rgb: {

          r: Math.floor(Math.random() * 256),

          g: Math.floor(Math.random() * 256),

          b: Math.floor(Math.random() * 256)

        }

      })

    }

  }

  pageLifetimes: {

    // 组件所在页面被展示时,立即调研 _randomColor 生成随机颜色值

    show() {

      console.log('show')

      this._randomColor()

    }

  }

})

 

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值