【Vue】2-11、组件的生命周期

一、生命周期 & 声明周期函数

生命周期(Life Cycle)是值一个组件从 创建 -> 运行 -> 销毁 的整个阶段,强调的是一个时间段。

生命周期函数是由 Vue 框架提供的内置函数,会伴随着组件的生命周期,自动按次序执行。

二、组件生命周期函数的分类

官方生命周期函数示意图:

生命周期钩子 | Vue.js

三、组件之间的数据共享 

1、父子组件之间的数据共享  

1)父 -> 子

父组件向子组件共享数据需要使用自定义属性

2)子 -> 父

子组件向父组件共享数据需要使用自定义事件

此处截图中父组件中的 this.countFromSon 有误!

2、兄弟组件之间的数据共享  

EventBus 的使用步骤:

  1. 创建 eventBus.js 模块,并向外共享一个 Vue 的实例对象

  2. 在数据发送方,调用 bus.$emit('事件名称',要发送的数据) 方法触发自定义事件

  3. 在数据接收方,调用 bus.$on('事件名称',事件处理函数) 方法注册一个自定义事件

四、ref 操作 DOM 元素 

1、什么是 ref ?

ref 用来辅助开发者在不依赖于 JQuery 的情况下获取 DOM 元素或组件的引用。

每个 vue 的组件实例上都包含一个 $refs 对象,里面存储着对应的 DOM 元素或组件的引用。

默认情况下,组件的 $refs 指向一个空对象。

2、使用 ref 引用组件实例

<Right ref="right"></Right>
<button @click="getRef">获取 right</button>methods: {getRef() {// 通过 this.refs 引用的名称可以引用组件的实例console.log(this.$refs.right);// 引用到组件的实例之后就可以调用组件上的 methods 方法this.$refs.right.add();},
},add() {console.log("add() 方法");
},

3、this.$nextTick() 方法  

showInput() {this.flag = true;this.$nextTick(() => {this.$refs.iptRef.focus();});
},

this.flag = true; 这条语句执行完以后,flag 的数据更新了,但是页面的 DOM 结构还没来得及渲染就执行 this.$refs.iptRef.focus(); 语句,便拿不到页面的 DOM 元素,此时的 ref 为 undefind,故需要使用 $nextTick(cb) 方法 cb 回调,即延后 this.$refs.iptRef.focus(); 语句到下一个 DOM 更新周期之后再执行。  

一  叶  知  秋,奥  妙  玄  心 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/447964.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Echars3D 饼图开发

关于vue echart3D 饼图开发 首先要先下载 "echarts-gl", 放在main.js npm install echarts-gl --save <template><div class"cointan"><!-- 3d环形图 --><div class"chart" id"cityGreenLand-charts"><…

C语言:详解操作符(上)

摘要&#xff1a; 本篇&#xff0c;我们将学习C语言中操作符的相关内容&#xff0c;操作符是C语言中重要的元素之一&#xff0c;在我们的代码中处处都有&#xff0c;下面我们将详细介绍操作符的相关内容&#xff0c;并结合一些代码例题加深印象。 目录 一、操作符的分类及介绍 …

Axure RP 网页版,让原型设计更高效

交互神器Axure RP是一种专业的快速原型设计工具&#xff0c;但Axure在用户体验上的缺陷也很明显。其设置交互方式相对繁琐&#xff0c;可视化不足、条件判断、变量、中继器等功能的使用需要陡峭的学习曲线。许多设计师正在寻找一个可以取代Axure的原型设计工具&#xff0c;即时…

图像去噪——SpatiallyAdaptiveSSID网络推理测试(详细图文教程)

SpatiallyAdaptiveSSID 是一种有效的图像去噪方法&#xff0c;它通过自适应地处理不同区域的噪声&#xff0c;能够在保持图像细节的同时&#xff0c;有效地去除噪声。 目录 一、SpatiallyAdaptiveSSID网络简介二、源码包准备2.1 测试集2.2 模型权重文件 三、测试环境四、推理测…

Spring框架——主流框架

文章目录 Spring(轻量级容器框架)Spring 学习的核心内容-一图胜千言IOC 控制反转 的开发模式Spring快速入门Spring容器剖析手动开发- 简单的 Spring 基于 XML 配置的程序课堂练习 Spring 管理 Bean-IOCSpring 配置/管理 bean 介绍Bean 管理包括两方面: Bean 配置方式基于 xml 文…

从零开始学Linux之gcc链接

目录 创建静态库并使用 创建动态库(共享库)并使用 链接&#xff1a;将.o目标文件链接起来生成一个可执行程序文件&#xff0c;可分为静态链接和动态链接 静态链接&#xff1a;链接器会找出程序所需的函数&#xff0c;然后将它们拷贝到执行文件&#xff0c;由于这种拷贝是完整…

双非本科准备秋招(14.1)—— 力扣刷题

今天做两个有点难度的题。 1、295. 数据流的中位数 手写堆实现&#xff1a; 加入元素&#xff1a; 如何维护一个中位数&#xff1f;我们考虑一下堆的特点&#xff0c;大顶堆堆顶是一个最大值&#xff0c;小顶堆堆顶是一个最小值&#xff0c;那么&#xff0c;如果我们可以把数…

路由重定向和别名

聚沙成塔每天进步一点点 本文内容 ⭐ 专栏简介1. 路由重定向实例场景&#xff1a;路由重定向的应用场景&#xff1a; 2. 路由别名实例场景&#xff1a;路由别名的应用场景&#xff1a; ⭐ 写在最后 ⭐ 专栏简介 Vue学习之旅的奇妙世界 欢迎大家来到 Vue 技能树参考资料专栏&…

【INTEL(ALTERA)】为什么 F-tile Serial Lite IV FPGA IP 设计示例会失败

说明 由于Intel Agilex 7 FPGA I 系列收发器-SoC 开发套件的时钟控制器 GUI 存在问题&#xff0c;当您需要配置芯片 Si5332 的 OUT1 时钟频率时&#xff0c;您可能会发现 F-tile Serial Lite IV 英特尔 FPGA IP设计示例失败。这是因为此 Si5332 GUI 存在问题;无法准确配置 OUT…

Python使用fastAPI实现一个流式传输接口

1. 使用fastapi实现流式传输 1.1 服务端 fastapi_server.py 编写服务端代码fastapi_server.py。服务端代码主要使用了fastapi和uvicorn两个库。 #!/usr/bin/env python # codingutf-8 # Time : 2024/1/31 19:13 # Software: PyCharm from fastapi import FastAPI from fa…

【JavaScript】var,let 和 const 的区别

先看一些前置知识&#xff1a; 此时输出 undefined。 全局作用域&#xff1a;全局都可以访问。函数作用域&#xff1a;只有函数内部可以访问。块级作用域&#xff1a;let 和 const 只能在块级作用域&#xff08;一对大括号包裹的代码片段&#xff09;中访问。let 和 const 在变…

怎么把图片的二维码提取出来?免费在线二维码转换成链接的方法

在部分情况下无法直接使用二维码展示内容&#xff0c;那么可以将二维码分解成链接后来使用&#xff0c;点击链接就可以跳转二维码的页面内容&#xff0c;这种方式可以在电脑或者手机上预览二维码内容。怎么提取二维码链接呢&#xff1f;下面小编来教大家二维码解码器的使用方法…