位置: IT常识 - 正文

Vue父子组件生命周期执行顺序是什么?(vue父子组件生命周期钩子执行顺序)

编辑:rootadmin
Vue父子组件生命周期执行顺序是什么?

推荐整理分享Vue父子组件生命周期执行顺序是什么?(vue父子组件生命周期钩子执行顺序),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue父子组件生命周期执行顺序activated,vue父子组件生命周期钩子函数执行顺序,vue父子组件生命周期钩子执行顺序,vue父子组件生命周期执行顺序的原理,vue父子组件生命周期函数,vue父子组件生命周期执行顺序,vue父子组件生命周期执行顺序,vue父子组件生命周期执行顺序,内容如对您有帮助,希望把文章链接给更多的朋友!

执行顺序:父组件先创建,然后子组件创建;子组件先挂载,然后父组件挂载,即“父beforeCreate-> 父create -> 子beforeCreate-> 子created -> 子mounted -> 父mounted”。

在单一组件中,钩子的执行顺序是beforeCreate-> created -> mounted->… ->destroyed,但当父子组件嵌套时,父组件和子组件各拥有各自独立的钩子函数,这些父子组件的这些钩子是如何交融执行,且执行顺序又是怎样的呢?

父子组件生命周期执行顺序

组件,分别在他们的钩子函数中打印日志,观察执行顺序。得到的结果如图所示,父组件先创建,然后子组件创建;子组件先挂载,然后父组件挂载。

父beforeCreate->父created->父beforeMount->子beforeCreate->子created->子beforeMount->子mounted->父mounted

子组件挂载完成后,父组件还未挂载。所以组件数据回显的时候,在父组件mounted中获取api的数据,子组件的mounted是拿不到的。

仔细看看父子组件生命周期钩子的执行顺序,会发现created这个钩子是按照从外内顺序执行,所以父子组件传递接口数据的解决方案是:

在created中发起请求获取数据,依次在子组件的created或者mounted中会接收到这个数据。

加载渲染过程

父beforeCreate->父created->父beforeMount->子beforeCreate->子created->子beforeMount->子mounted->父mounted

销毁过程

父beforeDestroy->子beforeDestroy->子destroyed->父destroyed

常用钩子简易版

父create->子created->子mounted->父mounted补充单一组件钩子执行顺序

activated, deactivated 是组件keep-alive时独有的钩子

beforeCreate

created

beforeMount

mounted

beforeUpdate

updated

activated

Vue父子组件生命周期执行顺序是什么?(vue父子组件生命周期钩子执行顺序)

deactivated

beforeDestroy

destroyed

errorCaptured

总结

beforeCreate执行时:data和el均未初始化,值为undefined

created执行时:Vue 实例观察的数据对象data已经配置好,已经可以得到data的值,但Vue 实例使用的根 DOM 元素el还未初始化

beforeMount执行时:data和el均已经初始化,但此时el并没有渲染进数据,el的值为“虚拟”的元素节点

mounted执行时:此时el已经渲染完成并挂载到实例上

beforeUpdate和updated触发时,el中的数据都已经渲染完成,但只有updated钩子被调用时候,组件dom才被更新。

在created钩子中可以对data数据进行操作,这个时候可以进行数据请求将返回的数据赋给data

在mounted钩子对挂载的dom进行操作,此时,DOM已经被渲染到页面上。

虽然updated函数会在数据变化时被触发,但却不能准确的判断是那个属性值被改变,所以在实际情况中用computed或watch函数来监听属性的变化,并做一些其他的操作。

所有的生命周期钩子自动绑定 this 上下文到实例中,所以不能使用箭头函数来定义一个生命周期方法 (例如 created: () => this.fetchTodos()),会导致this指向父级。

在使用vue-router时有时需要使用来缓存组件状态,这个时候created钩子就不会被重复调用了,如果我们的子组件需要在每次加载或切换状态的时候进行某些操作,可以使用activated钩子触发。

父子组件的钩子并不会等待请求返回,请求是异步的,VUE设计也不能因为请求没有响应而不执行后面的钩子。所以,我们必须通过v-if来控制子组件钩子的执行时机.

注意:在父组件传递接口的数据给子组件时,一定要在子组件标签上加上v-if="传递的接口数据"

在父组件的created中发请求获取数据,通过prop传递给子组件。子组件在created或者mounted中拿父组件传递过来的数据 这样处理是有问题的。在父组件调用接口传递数据给子组件时,接口响应显然是异步的。这会导致无论你在父组件哪个钩子发请求,在子组件哪个钩子接收数据。都是取不到的。当子组件的mounted都执行完之后,此时可能父组件的请求才返回数据。会导致,从父组件传递给子组件的数据是undefined。

解决方法1:

在渲染子组件的时候加上一个条件,data1是父组件调用接口返回的数据。当有数据的时候在去渲染子组件。这样就会形成天然的阻塞。在父组件的created中的请求返回数据后,才会执行子组件的created,mounted。最后执行父组件的mounted。

<div class="test"><children v-if="data1" :data="data1" ></children></div>解决方法2:

在子组件中 watch 监听,父组件获取到值,这个值就会变化,自然是可以监听到的

watch:{data:{deep:true,handler:function(newVal,oldVal) {this.$nextTick(() => {this.data = newValthis.data = newVal.url ? newVal.url : ''})}},}

从父组件点击调用接口并显示子组件,子组件拿到数据并监听在watch中调用方法并显示。

以下为子组件,data1是从子组件传递过来的数据。在created,mounted中都拿不到父组件调用接口返回的data1。 只能watch监听data1。并调用方法渲染子组件。

props:['data1'],watch:{data1:{deep:true,handler:function(newVal,oldVal) {this.$nextTick(() => {this.data1 = newValthis.showData1(this.data1)})}},}
本文链接地址:https://www.jiuchutong.com/zhishi/298846.html 转载请保留说明!

上一篇:5.OpenCV图像拼接(opencv拼接图片)

下一篇:【JavaScript】DOM和事件简介和文档加载流程以及DOM查询(上)案例(附源码)(javascript bom dom)

  • 个人注册电子税务局
  • 财务报表年报怎么更正
  • 其他应付款二级科目明细
  • 销售净水器营业执照范围
  • 个人所得税可以退几年前的?
  • 办公室租赁费计入什么科目
  • 公司接待考察团需要准备什么
  • 用友t3固定资产计提折旧后没有凭证
  • 机动车发票抵扣联有什么用
  • 增资印花税如何申报缴纳
  • 增值税发票当期能抵扣吗
  • 汇兑损失的原因
  • 同一控制下企业合并入账价值
  • 小规模企业所得税优惠政策最新2023
  • 公对公转账备注信息填错了怎么办
  • 股权转让企业所得税如何申报
  • 外币结算方式有哪几种
  • 取得的分成收入怎么计算
  • 工程款中包含增值税怎么处理
  • 房地产开发企业预收款预缴增值税
  • 罗马尼亚卫生部长
  • 购进土地会计分录
  • php数组函数面试题
  • 银行代扣的年费怎么退
  • 付员工经济补偿金计入工资总额吗
  • 跟银行借入长期存款
  • 退税报关的流程是什么
  • 欧罗巴山国家公园旅游攻略
  • 编制合并报表的母子公司是什么主体
  • 迭代器,生成器
  • h5链接js
  • 前端解决跨域问题的8种方案(最新最全)
  • 计提的附加税
  • 隐藏index.html
  • php处理异常
  • web前端开发 vue
  • sysstat命令
  • 季度是指
  • 水电费是收据能入账不
  • 合并报表中为什么要抵损益
  • 企业会计准则对收入的定义
  • 应交税费未交增值税
  • 金税盘开票如何增加商品编码
  • 五险一金的会计怎么做账
  • vue–router
  • 织梦怎么用模板建站
  • 工程完工补付工程款会计分录
  • 加计抵减会计分录其他收益
  • 会计需要装订资料有哪些
  • 财务报表与分析outcome2
  • 先预付货款,货到了怎么做账
  • 个人所得税征税对象是什么
  • 现金折扣要扣除折扣金额入账吗
  • 结转以后年度抵免的境外所得税怎么进行会计处理
  • 股息分红要交多少税
  • 认证失败,未获取到区域信息
  • 汇算清缴缴纳的所得税怎么做账
  • 工资及福利费科目
  • 餐饮企业老板
  • 营业账簿印花税怎么申报
  • 公司提前扣员工保险合法吗
  • 新成立的公司购买的家具可以计入主营业务成本吗
  • 新办企业是不是企业
  • 在mysql中使用视图的限制
  • windows7中ie浏览器怎么打开
  • mac 应用
  • thinkpad 8高配版
  • macos 音量快捷键
  • 如何在mac中安装五笔字型输入法
  • win7还原电脑系统的步骤
  • javascript解决了什么问题
  • nodejs 异步任务队列
  • shell脚本批处理
  • javascript图片
  • win7 python
  • python中zip函数的用法
  • 举例说明jquery的功能
  • jQuery bt气泡实现悬停显示及移开隐藏功能的方法
  • 怎么知道税控盘有没有注销
  • uk开票软件如何赋码
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设