Vue的生命周期和组件传参

Vue的生命周期包括beforeCreate、created、beforeMount、mounted、beforeUpdate、updated、beforeDestroy和destroyed八个阶段,分别对应实例的不同状态。文章详细解释了每个阶段的特点和用途。此外,还介绍了Vue组件间如何进行参数传递,包括父传子和子传父两种方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

什么是 vue 生命周期

        Vue 实例从创建到销毁的过程,就是生命周期。也就是从开始创建、初始化数据、编译模板、挂载Dom→渲染、更新→渲染、卸载等一系列过程,我们称这是 Vue 的生命周期。

 

生命周期函数


Vue 的生命周期总共分为8个阶段:创建前/后,载入前/后,更新前/后,销毁前/后。

1、beforeCreate(创建前)

表示实例完全被创建出来之前,vue 实例的挂载元素$el和数据对象 data 都为 undefined,还未初始化。
特点: 有this,没有data与methods

2、created(创建后)

数据对象 data 已存在,可以调用 methods 中的方法,操作 data 中的数据,但 dom 未生成,$el 未存在 。

特点: 有data,没有$el,dom节点
用处: ajax请求,定时器,事件监听

3、beforeMount(挂载前)

vue 实例的 $el 和 data 都已初始化,挂载之前为虚拟的 dom节点,模板已经在内存中编辑完成了,但是尚未把模板渲染到页面中。data.message 未替换。

特点: 有$el,数据没有渲染

4、mounted(挂载后)

vue 实例挂载完成,data.message 成功渲染。内存中的模板,已经真实的挂载到了页面中,用户已经可以看到渲染好的页面了。实例创建期间的最后一个生命周期函数,当执行完 mounted 就表示,实例已经被完全创建好了,DOM 渲染在 mounted 中就已经完成了。

特点: 有dom节点,数据也渲染
用处: 操作节点,ajax请求

5、beforeUpdate(更新前)

当 data 变化时,会触发beforeUpdate方法 。data 数据尚未和最新的数据保持同步。

特点:会执行多次  数据更新,dom节点没有更新

6、updated(更新后)

当 data 变化时,会触发 updated 方法。页面和 data 数据已经保持同步了。

特点:会执行多次 数据更新,dom节点也更新

7、beforeDestory(销毁前)

组件销毁之前调用 ,在这一步,实例仍然完全可用。
    特点: 数据可以更新,视图已经不更新
    用处: 移除事件监听,停止定时器

8、destoryed(销毁后)

组件销毁之后调用,对 data 的改变不会再触发周期函数,vue 实例已解除事件监听和 dom绑定,但 dom 结构依然存在。

特点: 没有this,切换视图与vue实例的联系

组件传参 

vue组件之间的参数传递:父传子。
先在子组件中通过props:[参数]设参,然后在父组件中通过<组件标签 :参数名=“要赋予的值”></组件标签>传参,最后在子组件中接参。

//父组件代码   渲染子组件
<Son  :sonName="uname" />

 // 子组件代码,接受父参数
export default {
  props: {
     sonName: String
  }
}

props是表示组件的参数部分,那么props有两种写法:

props:[“参数列表”]
比如:props:[‘prop01’,‘pro02’,‘pro03’,…]
props:{参数名1:{type:参数类型,required:是否是必须的参数true或者false,default:默认值},参数名2:{},参数名3:{},…}
比如:

props: {
    "MyTitle":{
      type: String,
      required:true,
      default:"XXX"
    }
  }

vue组件之间的参数传递:子传父。
简单来说和父传子其实差不多,但在这个过程中是父组件传可以改变父参数的方法给子组件,然后子组件通过这个方法的形参传递参数改变。

在子组件中定义一个带有语句this.$emit('键名', "值");方法 通过执行这个方法会将参数从底向上传
父组件通过@键="要改变的参数值=$event"接收参数


父组件核心代码:

<template>
  <div id="app">
    <!-- <MyHeader></MyHeader> -->
    <MyContent :MyTitle='msg' @newMsg="msg=$event"></MyContent>
    <!-- <MyBotton></MyBotton> -->
  </div>
</template>


子组件核心代码:

 methods: {
    fire:function(){
      this.$emit('newMsg', "传来的参数");
    }
  }
// 通过单击btn的单击事件触发
<button type="button" @click="fire()">改变title内容</button>

### 解决 PP-OCRv4 出现的错误 当遇到 `WARNING: The pretrained params backbone.blocks2.0.dw_conv.lab.scale not in model` 这样的警告时,这通常意味着预训练模型中的某些参数未能匹配到当前配置下的模型结构中[^2]。 对于此问题的一个有效解决方案是采用特定配置文件来适配预训练权重。具体操作方法如下: 通过指定配置文件 `ch_PP-OCRv4_det_student.yml` 并利用已有的最佳精度预训练模型 (`best_accuracy`) 来启动训练过程可以绕过上述不兼容的问题。执行命令如下所示: ```bash python3 tools/train.py -c configs/det/ch_PP-OCRv4/ch_PP-OCRv4_det_student.yml ``` 该方案不仅解决了参数缺失带来的警告,还能够继续基于高质量的预训练成果进行微调,从而提升最终检测效果。 关于蒸馏的概念,在机器学习领域内指的是将大型复杂网络(teacher 模型)的知识迁移到小型简单网络(student 模型)。这里 student 和 teacher 的关系是指两个不同规模或架构的神经网络之间的指导与被指导的关系;其中 teacher 已经经过充分训练并具有良好的性能,而 student 则试图模仿前者的行为模式以达到相似的效果但保持更高效的计算特性。 至于提到的 `Traceback` 错误信息部分,由于未提供具体的跟踪堆栈详情,难以给出针对性建议。不过一般而言,这报错往往涉及代码逻辑错误或是环境配置不当等问题。为了更好地帮助定位和解决问题,推荐记录完整的异常日志,并仔细检查最近修改过的代码片段以及确认依赖库版本的一致性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值