位置: 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)

  • 非盈利组织确认及所得税汇算怎么做
  • 员工交个人所得税对公司有什么影响
  • 存货跌价准备影响当期损益吗
  • 酒店购买的空调折旧计入管理费用吗
  • 企业所得税怎么缴纳
  • 一般纳税人混凝土税率
  • 500元以内的商品都有哪些
  • 5附加税政策优惠退税需要哪些资料
  • 会计凭证销毁时应注意哪些问题?
  • 跨年冲销营业外支出
  • 印花税的会计处理
  • 个人投资理财需要注意什么
  • 原始凭证分割单可以税前扣除吗
  • 汇算清缴调增的利润要进未分配吗
  • 股权转让缴印花税公司用进账吗
  • 个人技术服务费增值税税率是多少啊
  • 税金当月计提当月缴纳
  • 其他流动负债包含
  • 利润表中哪些属于营业外收入
  • 民间非营利组织会计制度会计科目
  • php处理xml
  • js时间格式转换时间戳
  • 拆迁货币什么意思
  • 消防器材怎么做?
  • 营改增后劳务发票税率
  • 会计分录的书写规范
  • 公司出租房租怎么交税
  • 包工包料工程要交哪些税
  • php数据表
  • PHP:image_type_to_mime_type()的用法_GD库图像处理函数
  • uni-app list
  • 在金税卡里面如何交社保
  • yii框架运行原理
  • 明细分类账户定义
  • 增值税的纳税时间是多久
  • 美团收购联联
  • php curl_setopt
  • 赠送顾客的商品怎么入账
  • 企业贷款利息可以开发票吗
  • 启动mysql的语句
  • mysql入门很简单
  • python 自定义异常
  • 小规模所得税怎么计算公式
  • 本期应补退税额为负数怎么申报
  • 小规模企业跨月发票如何冲红
  • 个人所得税0申报什么意思
  • 下列项目的进项税额可以从销售税额中抵扣的是
  • 投资性房地产公允价值模式账务处理
  • 预收账款要预交税金吗
  • 公司办理宽带套餐合法吗
  • 应缴纳房产税的房产
  • 金蝶多核算项目怎么查一个项目下的其他项目
  • 分公司做账报税
  • 零申报必须会计吗?自己可以操作吗
  • 什么计提折旧什么不计提折旧
  • mysql更改密码命令
  • window放大之后怎么缩小
  • rancheros github
  • 加载dll错误是什么意思
  • 苹果发布会最新消息
  • linux gunzip
  • win7如何重装系统电脑
  • win80xc0000001怎么修复
  • node.js http服务器
  • cocos2dx schedule
  • linux中的shell命令
  • 粉碎文件的快捷键
  • android基础教程
  • python3 args
  • linux创建用户的命令是什么
  • jquery常用的5个方法
  • 广东电子税务局财务报表在哪里查询
  • 国家级运动员怎么申请
  • 一般纳税人企业所得税5%还是25%
  • 郑州房产交契税在哪里交
  • 潍坊市的职工医保多少钱
  • 新车交购置税的流程图
  • 税控盘红字发票开具流程
  • 南川大观薰衣草花期
  • 小规模纳税人收什么税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设