uniapp页面生命周期和组件生命周期

知识技术 发表于:2023-05-16 最后更新于:2023-05-16 浏览:708
转载请务必注明: 来源:《建站管家》https://df81.com/news/515.html

页面的生命周期
onLoad 监听页面加载,其参数为上个页面传递的数据,参数类型为object(用于页面传参),参考示例

onShow 监听页面显示

onReady 监听页面初次渲染完成

onHide 监听页面隐藏

onUnload 监听页面卸载

onPullDownRefresh 监听用户下拉动作

onReachBottom 页面上拉触底事件的处理函数

onShareAppMessage 用户点击右上角分享 微信小程序

onPageScroll 监听页面滚动

onTabItemTap 当前是 tab 页时,点击 tab 时触发

<script>
 2 export default {
 3         data() {
 4             return {
 5                 title: 'Hello'
 6             }
 7         },
 8         onLoad() {
 9             console.log('页面加载')
10         },
11         onShow() {
12             console.log('页面显示')
13         },
14         onReady(){
15             console.log('页面初次显示')
16         },
17         onHide() {
18             console.log('页面隐藏')
19         },
20         onUnload() {
21             console.log('页面卸载')
22         },
23         onBackPress(){
24             console.log('页面返回...')
25         },
26         onShareAppMessage() {
27             console.log('分享!')
28         },
29         onReachBottom() {
30             console.log('下拉加载...')
31         },
32         onPageScroll(){
33             console.log('页面滚动...')
34         },
35         onPullDownRefresh() {
36             console.log('上拉刷新...')
37             uni.stopPullDownRefresh();
38         },
39         
40         // #ifdef APP-PLUS
41         onNavigationBarButtonTap(){
42             
43         },
44         // #endif
45         
46         methods: {
47             tap(){
48                 console.log('tap点击!');
49             }
50         }
51     }
52 </script>


组件的生命周期

beforeCreate 组件初始化,但数据原生观测、自定义观测(event\watcher)没生成之前。 未完全创建阶段

created 组件创建后,但还未挂载 完全创建阶段

beforeMount 组件渲染后,挂载前。 渲染后待挂载

mounted 组件挂载到页面 可用 vm.$el 访问 挂载OK

beforeUpdate 虚拟 DOM 重新渲染和打补丁之前 再次渲染前

updated 组件 DOM 已经更新 再次渲染后

activated keep-alive 组件激活时调用。 当前组件被激活:显示

deactivated keep-alive 组件停用时调用。 当前组件隐藏

beforeDestroy 实例销毁之前调用。实例仍然完全可用。 销毁前

destroy Vue 实例销毁后调用


注:挂载阶段,先渲染组件,然后挂载组件。

<script>
    export default {
        data() {
            return {
                title: 'Hello'
            }
        },
        props:{},
        beforeCreate() {
            console.log('组件初始化,未完全创建阶段')
        },
        created() {
            console.log('组件创建后,但还未挂载')
        },
        beforeMount(){
            console.log('渲染后待挂载')
        },
        mounted() {
            console.log('组件挂载到页面OK,可用 vm.$el 访问')
        },
        beforeUpdate() {
            console.log('再次渲染前')
        },
        updated(){
            console.log('再次渲染后')
        },
        activated() {
            console.log('当前组件被激活:显示')
        },
        deactivated() {
            console.log('当前组件隐藏')
        },
        beforeDestroy(){
            console.log('销毁前')
        },
        destroy() {
            console.log('销毁后')
           
        },
        methods: {
            tap(){
                console.log('tap点击!');
            }
        }
    }
</script>

点赞 (0)

收藏 (0)

本站部分信息来源网络,如有侵权,请联系QQ:1062129401删除。

上一篇: 《建站管家》二次开发文档

下一篇: UniAPP+UviewUI多图上传示例代码

请先登录后,再发表评论 ~ ~
发表评论
发表评论
发表帖子
广告位招租( ¥5 / 天 )
点击咨询
相关帖子

如果要判断文件是否存在,用函数 is_file(),如果要判断目录是否存在,用函数 is_dir()
用宝塔安装TP程序后,网站前台可以访问,后台无法访问,不是程序问题,而是web服务器环境配置问题(PHP配置),出现这种问题,一般是windows主机安装宝塔造成的,linux安装宝塔不会出现此错误
广告位招租( ¥3 / 天 )
点击咨询
广告位招租( ¥2 / 天 )
点击咨询
广告位招租( ¥1 / 天 )
点击咨询
最新帖子

我现在众筹开发中英双语商城系统:开发完成后,你们对外销售前5套你们分成80%,我20%,5套后五五分成,自用免费授权
网站已经上线的老铁,记得把默认联系方式修改一下
小朋友,你爸爸是谁啊?这很单纯的,就像我们碰到别人会问:你吃过饭了吗?类似;许多人初次相识,经常会问:你是做什么的啊?你做什么,好像决定你收入的高低,你,资产的范围
在线客服