Vue生命周期

4个阶段:

        初始化阶段:beforeCreate和created

        挂载阶段:beforeMount和mounted

        更新阶段:beforeUpdate和updated

        销毁阶段:beforeDestroy和destroyed

        缓存:activated和deactivated

初始化阶段:

        初始化全局组件=>初始化父子关系树=>初始化自定义组件的自定义事件=>初始化插槽信息和得到h函数=>调用beforeCreate生命周期=>初始化initInjections=>初始化state(props、methods、data、computed、watch)=>初始化Provide =>调用created生命周期=>进入挂载阶段

        我们在beforeCreate里拿不到props、methods、data、computed、watch

        在created里可以拿到props、methods、data、computed、watch

挂载阶段:

        通过compile去解析templated的到AST语法树=>调用beforeMount生命周期=>updateComponent=>绑定观察者Watcher=>调用mounted生命周期

        updateComponent的核心是对通过compile解析templated的到AST语法树进行转换成真实DOM然后渲染到页面

        解析和过程:

                AST语法树通过h函数抽离出VNode(虚拟DOM)=> 通过diff算法的patch函数将VNode变换成真实DOM渲染到页面

        注意:VNode的顺序是子在前父在后 父子生命周期执行顺序:父beforeCreate=>created=>beforeMount=>子beforeCreate=>created=>beforeMount=>mounted=>父mounted

更新阶段:

        对挂载阶段绑定的观察者Watcher进行触发=>挂载阶段绑定Watcher时会传入before方法before方法内主要就是调用beforeUpdate生命周期 当数据改变时Watcher会先触发before方法然后触发Watcher自身的update方法在处理完数据变更后会调用updated生命周期

销毁阶段:

        将实例从其父级实例中删除=>移除实例的依赖=>移除实例内响应式数据的引用=>删除子组件实例。

缓存:

        场景模拟:tab切换

        当keep-alive中的组件被点击时,activated生命周期函数被激活执行一次,切换到其它组件时,deactivated被激活。如果没有keep-alive包裹,没有办法触发activated生命周期函数。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值