自定义组件

nextTick

解释:延迟一部分操作到下一个时间片再执行。(类似于 setTimeout)

基础库 3.15.104 开始支持,低版本需做兼容处理。

参数:function callback

说明:自定义组件中的 setData 和 triggerEvent 等接口为同步操作,当这几个接口被连续调用时,都是在一个同步流程中执行完的,因此若逻辑不当可能会导致出错。

举例:当父组件的 setData 引发了子组件的 triggerEvent,进而使得父组件又进行了一次 setData,期间有通过 s-if 语句对子组件进行卸载,就有可能引发奇怪的错误,所以对于不需要在一个同步流程内完成的逻辑,可以使用此接口延迟到下一个时间片再执行。

示例:

  1. Component({
    doSth() {
    this.setData({number: 1}) // 直接在当前同步流程中执行

    swan.nextTick(() => {
    this.setData({number: 3}) // 在当前同步流程结束后,下一个时间片执行
    })

    this.setData({number: 2}) // 直接在当前同步流程中执行
    }
    });

下拉刷新菜单