前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >面试:Vue.js嵌套组件生命周期执行顺序是什么?

面试:Vue.js嵌套组件生命周期执行顺序是什么?

作者头像
张张
修改2019-12-27 17:58:53
2K0
修改2019-12-27 17:58:53
举报
文章被收录于专栏:前端全栈开发者

一次面试被问到的问题,第一次还确实有点懵逼,特此记录下来。

有组件A,组件B,组件C,组件C是组件B的子组件,组件B又是组件A的子组件,那么直观的层级结构如下:

代码语言:javascript
复制
ComponentA
--ComponentB
----ComponentC

问:他们之间生命周期函数的调用顺序是什么?

下面的代码表示上述结构,全局注册了三个组件Comp、childrenA 和 childrenB。在 childrenA 中引用 childrenB,在 Comp 中 引用 childrenA。

代码语言:javascript
复制
Vue.component('comp', {
    template: '<div><children-a></children-a></div>',
    beforeCreate() {
        console.log('Comp beforeCreate')
    },
    created() {
        console.log('Comp created')
    },
    beforeMount() {
        console.log('Comp beforeMount')
    },
    mounted() {
        console.log('Comp mounted')
    },
})
Vue.component('childrenA', {
    template: '<div><children-b></children-b></div>',
    beforeCreate() {
        console.log('--childrenA beforeCreate')
    },
    created() {
        console.log('--childrenA created')
    },
    beforeMount() {
        console.log('--childrenA beforeMount')
    },
    mounted() {
        console.log('--childrenA mounted')
    },
})
Vue.component('childrenB', {
    template: '<div>{{text}}</div>',
    data() {
        return {
            text: 'childrenB'
        }
    },
    beforeCreate() {
        console.log('----childrenB beforeCreate')
    },
    created() {
        console.log('----childrenB created')
    },
    beforeMount() {
        console.log('----childrenB beforeMount')
    },
    mounted() {
        console.log('----childrenB mounted')
    },
})
new Vue({
    el: '#app'
})

输出结果如下:

代码语言:javascript
复制
Comp beforeCreate
Comp created
Comp beforeMount
--childrenA beforeCreate
--childrenA created
--childrenA beforeMount
----childrenB beforeCreate
----childrenB created
----childrenB beforeMount
----childrenB mounted
--childrenA mounted
Comp mounted

可以看到,先执行父级的beforeCreate、created 和 beforeMount,然后再去执行子组件的beforeCreate、created 和 beforeMount,如果子组件下面没有子组件了,就执行 mounted,然后再返回父级执行 mounted。

整个过程用图表示如下:

Vue嵌套组件生命周期执行顺序

完!


本文代表个人观点,内容仅供参考。若有不恰当之处,望不吝赐教!

如果对你有一点点帮助,可以点个关注。

本文链接:https://zhangbing.site/2018/12/05/Vue-js嵌套组件生命周期执行顺序/

作者简介:做工程不做码农(微信公众号同名),Web前端工程师,7年开发经验,坐标杭州,聚焦大前端技术和技术成长的公众号,分享我的原创或精选文章,欢迎关注。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-12-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
作者已关闭评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档