快应用的生命周期

快应用的生命周期

  • 页面的生命周期:onInit、onReady、onShow、onHide、onDestroy、onBackPress、onMenuPress
  • 页面的状态: 显示、隐藏、销毁
  • APP的生命周期:onCreate、onDestroy

页面的生命周期接口的调用顺序:

  • 打开页面A:onInit() -> onReady() -> onShow()
  • 在页面A打开页面B:onHide()
  • 从页面B返回页面A:onShow()
  • A页面返回:onBackPress() -> onHide() -> onDestroy()

页面的生命周期

由于页面通过 ViewModel 渲染,那么页面的生命周期指的是 ViewModel 的生命周期,包括常见:onInit、onReady、onShow在页面创建时触发调用。

onInit()

表示 ViewModel 的数据 (event,props,data)已经准备好;所以你可以使用 props, data中的数据

    data: {
       // 生命周期的文本列表
        lcList:[]
    },
    onInit() {
        this.$page.setTitleBar({text: '生命周期'})
        this.lcList.push('onInit')
        
        console.info('触发:onInit')
        console.info('执行:获取data的lcList属性: ${this.lcList}')
    }

onReady()

表示 ViewModel 的模板已经编译完成,所以你可以获取DOM节点

    onReady() {
        this.lcList.push('onReady')
        
        console.info('触发:onReady')
        console.info('执行:获取模板节点 ${this. rootElement()}')
    }

onShow(),onHide()

App中可以同时运行多个页面,但是每次只能显示其中一个页面;这点不同与纯前端开发,浏览器页面中每次只能有一个页面,当前页签打开另一个页面,
上一个页面就销毁了;不过和SPA开发倒有点相似,切换页面但浏览器全局Context是共享的

所以页面的切换,就产生了新的事件:页面被切换隐藏时调用onHide(),页面被切换重新显示时就调用onShow()

判断页面的显示状态,可以调用 ViewModel 的 ¥visible 属性:true:显示 false:隐藏

    onShow() {
        this.lcList.push('onShow')
        
        console.info('触发:onShow')
        console.info('执行:获取页面显示状态属性 ${this.visible}') // true
    }
    onHide() {
        this.lcList.push('onHide')
        
        console.info('触发:onHide')
        console.info('执行:获取页面显示状态属性 ${this.visible}') // false
    }
    

onDestroy()

页面被销毁时调用,被销毁的可能原因有:

  1. 用户从当前页面返回到上一个页面
  2. 用户打开了太多的页面,架构自动销毁部分页面,避免占用资源

页面销毁时应该做一些释放资源的操作,比如:取消订阅监听 geolocation.unsubscribe()

判断页面是否处于被销毁状态,可以调用 ViewModel 的 $valid 属性:
true: 存在 false:销毁

    onDestroy() {
        this.lcList.push('onDestroy')
        
        console.info('触发:onDestroy')
        console.info('执行:获取页面被销毁,销毁状态 ${this. $.valid},应该做取消接口订阅监听的操作:geolocation.unsubsrible()')
        setTimeout(function() {
            console.info('执行:页面已被销毁,不会执行')
        }.bind(this), 0)
    }

onBackPress()

当用户点击 返回实体按钮、左上角返回按钮、调用返回API时触发该事件

如果事件响应方法最后返回 true 表示不返回,自己处理业务逻辑;
否则:不返回数据,或者返回其它数据

    onBackPress() {
        this.lcList.push('onBackPress')
        
        // true:表示自己处理,否则默认返回上一页
        // return true
    }

onMenuPress()

当使用原生的顶部标题栏时,可以通过manifest.json中的menu属性配置是否显示右上角的菜单

   "display": {
        "titleBarBackgroundColor": "#000000",
        "titleBarTextColor": "#ffffff",
        "backgroundColor": "#efefef",
        "menu": true, #菜单栏是否显示
        "pages": { # 对应每个页面的显示设置
            "Home": {
                "titleBarText": "Gank",
                "menu": true // 菜单标题栏显示
            },
            "About": {
                "titleBarText": "关于",
                "menu": false // 菜单标题栏隐藏
            }
        }
    }

    onMenuPress() {
        this.lcList.push('onMenuPress')
        
        console.info('触发:onMenuPress()')
    }

页面的状态

App中允许多个页面同时存在并运行,但当前仅显示其中一个,因此每个页面就会处于多个状态的一个状态

  • 显示:该页面就是当前APP正在显示的页面,用$visible判断
  • 隐藏:该页面上打开新页面后,该页面被隐藏,用$visible判断
  • 销毁:该页面因某原因销毁后,就不会再执行里面的代码,用$valid判断

APP的生命周期

APP的生命周期提供了两个回调函数:onCreate, onDestroy,可以app.ux中定义回调函数

export default {
    onCreate() {
        console.info('Application onCreate')
    },
    
    onDestroy() {
        console.info('Application onDestroy')
    },
    
    // 定义APP数据,可以通过 this.$app.$def.globalData访问
    globalData: {
        name: '这是App存的数据'
    },
    // 定义App全局方法,可以通过 this.$app.$def.mehtod()访问
    method() {
        console.info('这是app的方法')
    },
    // mainfest
}

关于$app与$app.$def

$app与$app.$def(后面简称$def)是两个不同的对象;

前者代表框架为开发者暴露提供的APP对象;后者代表开发者在app.ux中导出的对象,放置业务相关的全局数据和方法;

前者对象拥有onCreate, onDestroy生命周期;当应用启动时会执行onCreate方法,里面执行this.variable1的赋值是在$app对象上;

后者对象中的onCreate, onDestroy方法并不会执行,作用仅仅只是把方法复制到前者对象上而已;

你可能感兴趣的:(快应用的生命周期)