vue3组件通信与props


title: vue3组件通信与props
date: 2024/5/31 下午9:00:57
updated: 2024/5/31 下午9:00:57
categories:

  • 前端开发

tags:

  • Vue3组件
  • Props详解
  • 生命周期
  • 数据通信
  • 模板语法
  • Composition API
  • 单向数据流

在这里插入图片描述

Vue 3 组件基础

在 Vue 3 中,组件是构建用户界面的基本单位,它们是可复用的 Vue 实例,具有自己的模板、数据、方法等。组件化开发使得代码更加模块化,易于管理和维护。以下是 Vue 3 组件的基础知识:

1. 组件的创建与注册

在 Vue 3 中,组件需要先定义后使用。定义组件的方式有两种:全局注册和局部注册。

全局注册

全局注册的组件可以在任何地方使用,通过 app.component 方法进行注册:

import { createApp } from 'vue';
import App from './App.vue';const app = createApp(App);app.component('my-component', {// 组件选项
});app.mount('#app');
局部注册

局部注册的组件只能在注册它的组件内部使用,通常在组件的 components 选项中进行注册:

export default {components: {'my-component': {// 组件选项}}
}

2. 组件选项

组件选项包括模板、数据、方法、生命周期钩子等。

模板 (Template)

组件的模板定义了组件的结构,可以使用 HTML 和 Vue 的模板语法:

<template><div><h1>{{ title }}</h1><p>{{ content }}</p></div>
</template>
数据 (Data)

组件的数据是响应式的,需要是一个函数,返回一个数据对象:

export default {data() {return {title: 'Hello Vue 3',content: 'Welcome to Vue 3 component basics.'};}
}
方法 (Methods)

组件的方法定义在 methods 选项中,可以在模板中通过事件绑定来调用:

export default {methods: {greet() {alert('Hello from Vue 3 component!');}}
}
生命周期钩子 (Lifecycle Hooks)

Vue 3 提供了多个生命周期钩子,允许你在组件的不同阶段执行代码。例如:

export default {created() {console.log('Component created');},mounted() {console.log('Component mounted');}
}

3. 组件通信

组件之间的通信是 Vue 应用中的常见需求,Vue 3 提供了多种通信方式,包括 props、自定义事件、插槽等。

Props

Props 允许父组件向子组件传递数据:

// 子组件
export default {props: {message: String}
}// 父组件
<child-component :message="hello"></child-component>
自定义事件

子组件可以通过自定义事件向父组件传递数据:

// 子组件
this.$emit('my-event', data);// 父组件
<child-component @my-event="handleEvent"></child-component>
插槽 (Slots)

插槽允许父组件向子组件传递内容:

<!-- 子组件 -->
<slot></slot><!-- 父组件 -->
<child-component><p>This content is passed to the child component via slot.</p>
</child-component>

4. 组件的复用与组合

Vue 3 鼓励组件的复用和组合,通过 props、插槽等方式,可以构建出高度可复用的组件库。同时,Vue 3 还引入了 Composition API,使得组件的逻辑更加清晰和易于复用。

什么是 props?

在 Vue.js 框架中,props 是一个组件的属性,它可以接收来自父组件的数据,并将其传递到子组件中。props 使得子组件能够接收外部传入的信息,从而可以在不需要知道外部具体细节的情况下,实现与父组件的交互和数据传递。

Props 的作用

  1. 传参:父组件可以通过 props 将数据传递给子组件。
  2. 验证数据类型:在定义 props 时,可以指定期望的数据类型,这样 Vue 会在开发过程中进行类型检查,并在浏览器控制台中抛出警告,有助于提前发现潜在问题。
  3. 设置默认值:如果父组件没有传递相应的 prop,可以设置默认值以确保子组件能够接收到一个合理的默认值。

Props 的使用

在 Vue 3 中,定义 props 的方式有几种,包括使用字符串数组、对象形式以及使用 TypeScript 的类型注解。

字符串数组形式
export default {props: ['message']
}

这表示组件期望接收一个名为 messageprop,它是一个字符串类型。

对象形式
export default {props: {message: String,title: {type: String,default: 'Default Title'}}
}

这种方式下,message 被指定为字符串类型,而 title 被指定为字符串类型,并且有一个默认值。

TypeScript 类型注解

在使用 TypeScript 时,可以利用类型注解来定义 props

export default {props: {message: string,title: string}
}

Props 的传递

在父组件中,通过在模板中使用 v-bind 指令或者简写为 : 来传递 props

<!-- 父组件 -->
<child-component :message="parentMessage"></child-component>

在这里,parentMessage 是父组件中的一个数据属性,它将被传递给名为 child-component 的子组件。

Props 的验证

在 Vue.js 中,props 验证是指对组件传入的 props 进行类型检查和默认值设置等验证。Vue 提供了一个可选的验证功能,可以在定义 props 时进行设置。以下是一些常见的 props 验证规则:

  1. 类型验证:可以指定 props 的类型,如 StringNumberBooleanArrayObject 等。
  2. 默认值:可以为 props 设置默认值,如果未传入 prop,则使用默认值。
  3. 必需性:可以指定 props 是否为必需,如果为必需,则必须在父组件中传入。
  4. 自定义验证:可以使用 validator 函数进行自定义验证。
  5. 单位转换:对于数值类型,可以指定单位,如 px% 等,Vue 会自动进行单位转换。

下面是一个使用 props 验证的例子:

export default {props: {// 基本类型验证title: {type: String,default: '默认标题'},// 数值类型验证,可以指定单位width: {type: Number,default: 100,validator: (value) => {return value >= 0; // 自定义验证,确保宽度非负}},// 数组类型验证items: {type: Array,default: () => []},// 对象类型验证config: {type: Object,default: () => ({})},// 布尔值类型验证isActive: {type: Boolean,default: false}}
}

在这个例子中,title 被验证为字符串类型,有一个默认值;width 被验证为数值类型,有一个默认值,并且有一个自定义的验证函数确保它非负;items 被验证为数组类型,有一个默认的空数组;config 被验证为对象类型,有一个默认的空对象;isActive 被验证为布尔类型,有一个默认的 false 值。

如果父组件传递给子组件的 props 不满足这些验证规则,Vue 将抛出一个警告。这些验证规则有助于确保组件接收到的数据是预期的类型和格式,从而提高组件的健壮性。AD:首页 | 一个覆盖广泛主题工具的高效在线平台

动态Props

在Vue中,动态Props指的是父组件向子组件传递的Props值可以在运行时动态确定。这可以通过使用v-bind指令或简写为:来实现。动态Props的值可以是表达式、计算属性或方法返回的结果。

<template><ChildComponent :prop-name="dynamicValue" />
</template>
<script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent},data() {return {dynamicValue: '动态值'};}
};
</script>

单向数据流

在Vue中,单向数据流指的是数据只能从父组件流向子组件,不能反向流动。这是通过propsemit方法实现的。props用于父组件向子组件传递数据,而emit方法允许子组件向父组件发送事件。
AD:专业搜索引擎

父子组件通信

父子组件通信主要有以下几种方式:

  1. Props:父组件通过Props向子组件传递数据。
  2. ** e m i t 方法 ∗ ∗ :子组件通过 ‘ emit 方法**:子组件通过` emit方法:子组件通过emit方法触发事件,父组件通过@eventName`监听这些事件。
<!-- 父组件 -->
<template><ChildComponent @child-event="handleChildEvent" />
</template>
<script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent},methods: {handleChildEvent(data) {console.log('收到子组件的事件:', data);}}
};
</script>
<!-- 子组件 -->
<template><button @click="sendMessageToParent">发送消息给父组件</button>
</template>
<script>
export default {methods: {sendMessageToParent() {this.$emit('child-event', 'Hello from child!');}}
};
</script>

非父子组件通信

非父子组件通信有以下几种方式:

  1. Provide 和 Inject:祖先组件通过provide选项来提供变量,所有的子孙组件都可以通过inject选项来接收这个变量。
    AD:漫画首页
  2. Event Bus:创建一个中央事件总线实例,不同组件通过触发或监听事件来进行通信。
// 创建Event Bus实例
const eventBus = new Vue();// 祖先组件
eventBus.$emit('update-data', 'some data');// 后代组件
eventBus.$on('update-data', (data) => {console.log('收到数据:', data);
});

Props 的限制

  1. 类型限制:可以指定props的类型,如StringNumberBoolean等。
  2. 默认值:可以为props设置默认值。
  3. 必需性:可以指定props是否为必需。
  4. 自定义验证:可以使用validator函数进行自定义验证。
  5. 单位转换:对于数值类型,可以指定单位,如px%等,Vue会自动进行单位转换。

总结

Vue.js通过提供灵活的组件通信机制,使得前端开发更加高效和模块化。父子组件之间的通信通过propsemit实现,遵循单向数据流原则;非父子组件间则可以通过provideinject,或者事件总线来实现。这些通信机制不仅使得组件之间的数据传递更加清晰,也提高了应用的可维护性。同时,props的验证机制确保了组件接收到的数据是符合预期格式的,增加了组件的稳定性。

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

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

相关文章

判断自守数-第13届蓝桥杯选拔赛Python真题精选

[导读]&#xff1a;超平老师的Scratch蓝桥杯真题解读系列在推出之后&#xff0c;受到了广大老师和家长的好评&#xff0c;非常感谢各位的认可和厚爱。作为回馈&#xff0c;超平老师计划推出《Python蓝桥杯真题解析100讲》&#xff0c;这是解读系列的第75讲。 判断自守数&#…

蓝桥杯高频考点-与日期相关的题目

文章目录 前言1. 如何枚举合法日期1.1 预存每个月的天数1.2 封装一个判断日期是否合法的函数1.3 枚举日期并判断日期是否合法 2. 判断日期是否为回文日期2.1 将日期当作字符串进行处理2.2 将日期当作一个8位数进行处理 3. 给定初始日期&#xff0c;计算经过n天后对应的日期3.1 …

职场中,那些35岁以上的测试猿到底去哪了?

&#x1f525; 交流讨论&#xff1a;欢迎加入我们一起学习&#xff01; &#x1f525; 资源分享&#xff1a;耗时200小时精选的「软件测试」资料包 &#x1f525; 教程推荐&#xff1a;火遍全网的《软件测试》教程 &#x1f4e2;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1…

使用KEPServer连接欧姆龙PLC获取对应标签数据(标签值类型改为字符串型)

1.创建通道&#xff08;通道&#xff09;&#xff0c;&#xff08;选择对应的驱动&#xff0c;跟当前型号PLC型号对应&#xff09;。 2.创建设备&#xff0c;&#xff08;填入IP地址以及欧姆龙的默认端口号&#xff1a;44818&#xff09; 3.创建对应的标签。这里关键讲诉下字…

AI 网页解锁器,用于网页抓取一切 | 最快的验证码解决服务

想象一下&#xff0c;解锁互联网的全部潜力&#xff0c;数据自由流动&#xff0c;没有任何障碍阻挡你获取所需信息。在网络爬虫的世界里&#xff0c;这个梦想常常会遇到障碍&#xff1a;CAPTCHA和反机器人措施&#xff0c;这些措施旨在保护网站免受自动化访问的侵害。但如果有一…

【VSCode】快捷方式log去掉分号

文章目录 一、引入二、解决办法 一、引入 我们使用 log 快速生成的 console.log() 都是带分号的 但是我们的编程习惯都是不带分号&#xff0c;每次自动生成后还需要手动删掉分号&#xff0c;太麻烦了&#xff01; 那有没有办法能够生成的时候就不带分号呢&#xff1f;自然是有…

uni-app的网络请求库封装及使用(同时支持微信小程序)

其实uni-app中内置的uni.request()已经很强大了&#xff0c;简单且好用。为了让其更好用&#xff0c;同时支持拦截器&#xff0c;支持Promise 写法&#xff0c;特对其进行封装。同时支持H5和小程序环境&#xff0c;更好用啦。文中给出使用示例&#xff0c;可以看到使用变得如此…

【C++】——string模拟实现

前言 string的模拟实现其实就是增删改查&#xff0c;只不过加入了类的概念。 为了防止与std里面的string冲突&#xff0c;所以这里统一用String。 目录 前言 一 初始化和销毁 1.1 构造函数 1.2 析构函数 二 迭代器实现 三 容量大小及操作 四 运算符重载 4.1 bool…

Unity【入门】脚本基础

Unity脚本基础 文章目录 1、脚本基本规则1、创建规则2、MonoBehavior基类3、不继承MonoBehavior的类4、执行的先后顺序5、默认脚本内容 2、生命周期函数1、概念2、生命周期函数有哪些3、生命周期函数支持继承多态 3、Inspector窗口可编辑的变量4、Mono中的重要内容1、重要成员2…

冯喜运:5.31晚间黄金原油行情分析及尾盘操作策略

【黄金消息面分析】&#xff1a;周五&#xff08;5月31日&#xff09;&#xff0c;最新发布的数据显示&#xff0c;美国4月核心PCE物价指数月率录得0.2%&#xff0c;低于预期(0.3%)&#xff0c;经济学家认为&#xff0c;核心指数比整体指数更能反映通胀。除此之外&#xff0c;美…

HackTheBox-Machines--Sense

Popcorn 测试过程 1 信息收集 服务器开启80、443端口 80端口 访问 80 跳转到 443 – https://10.129.196.51/ &#xff0c;该页面是 pfSense 登录界面&#xff0c;默认密码是&#xff1a; admin/pfSense&#xff0c;使用默认账号密码登录失败 目录扫描 ./gobuster dir -u htt…

深度神经网络——什么是线性回归?

线性回归是一种用于预测或可视化的算法 两个不同特征/变量之间的关系。 在线性回归任务中&#xff0c;要检查两种变量&#xff1a; 因变量和自变量。 自变量是独立的变量&#xff0c;不受其他变量的影响。 随着自变量的调整&#xff0c;因变量的水平将会波动。 因变量是正在研究…

三体中的冯诺依曼

你叫冯诺依曼&#xff0c;是一位科学家。你无法形容眼前的现态&#xff0c;你不知道下一次自己葬身火海会是多久&#xff0c;你也不知道会不会下一秒就会被冰封&#xff0c;你唯一知道的&#xff0c;就是自己那寥寥无几的科学知识&#xff0c;你可能会抱着他们终身&#xff0c;…

《QT实用小工具·六十九》基于QT开发的五子棋AI游戏

1、概述 源码放在文章末尾 该项目实现了五子棋对战AI&#xff0c;可以享受和AI下棋的快乐&#xff0c;项目实现思路如下&#xff1a; 博弈树 ●Alpha-Beta剪枝(性能提高较大) ●启发式搜索(性能提高较大) ●落子区域限制(性能提高较大) ●Zobrist哈希(性能小幅提升) ●Qt…

数据治理基础知识

文章目录 基本概念相关名词术语数据治理对象 基本概念 1&#xff09;从管理者视角看数据治理 数据治理是企业发展战略的组成部分&#xff0c;是指导整个集团进行数字化变革的基石&#xff0c;要将数据治理纳入企业的顶 层规划&#xff0c;各分/子公司、各业务部门都需要按照企…

软考高级系统规划与管理师适合什么人考?有什么优势?

系统规划与管理师适合什么人考&#xff1f; 适合以下几类人群&#xff1a; 1. 信息技术服务规划人员&#xff1a;从事信息技术服务规划工作&#xff0c;负责制定和优化IT服务规划的人 2. 信息系统运行维护管理人员&#xff1a;负责信息系统日常运行维护、确保系统稳定性和可…

【前端】Mac安装node14教程

在macOS上安装Node.js版本14.x的步骤如下&#xff1a; 打开终端。 使用Node Version Manager (nvm)安装Node.js。如果你还没有安装nvm&#xff0c;可以使用以下命令安装&#xff1a; curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.1/install.sh | bash 然后关…

变压器励磁涌流MATLAB仿真模型

微❤关注“电气仔推送”获得资料&#xff08;专享优惠&#xff09; 变压器励磁涌流的产生机理 1、变压器是电力系统的关键部分&#xff0c;在实际的 运行中&#xff0c;变压器需要进行相应的充电&#xff0c;而在充电的过 程中&#xff0c;就需要进行开合闸作业。在开合闸作业…

【Linux】磁盘结构文件系统软硬链接动静态库

目录 一.磁盘结构 1、磁盘的物理结构 2、磁盘的存储结构 3、磁盘的逻辑结构 二.文件系统 1、对IO单位的优化 2、磁盘分区与分组 3、对分组的具体管理方法 4、文件操作 三.软硬链接 1、理解硬链接 2、理解软连接 3、理解.和.. 四、动静态库 1、什么是动静态库 2、…

Flutter基础 -- Dart 语言 -- 基础类型

目录 0. 配置 1. 变量 1.1 弱类型 var Object dynamic 1.2 强类型 1.3 使用场景 var 简化定义变量 查询参数定义 返回的实例对象 2. 常量 final 和 const 2.1 相同点 类型声明可以省略 初始后不能再赋值 不能和 var 同时使用 2.2 不同点 const 需要确定的值 …