vue3组件通信

props方式

1.父传子

父组件传递
<template><Child :car="car"/>
</template>
<script setup lang="ts">
import {ref} from 'vue'
import Child from './Child.vue'
let car = ref('宝马')
</script>子组件接收
<template><div class="child">{{ car }}</div>
</template>
<script setup lang="ts">
defineProps(['car'])
</script>

2.子传父

父组件传递
<template><Child :car="car" :sendValue="sendValue"/>
</template>
<script setup lang="ts">
import {ref} from 'vue'
import Child from './Child.vue'
let car = ref('宝马')
function sendValue(value) {car.value=value
}
</script>子组件接收
<template><div class="child">{{ car }}</div><div @click="sendValue('奔驰')">点击</div>
</template>
<script setup lang="ts">
let refValue = defineProps(['car','sendValue'])
console.log(refValue.car,refValue.sendValue)
</script>

3、自定义事件方式

父组件传递,一个自定义事件@sendValue="sendValue"
<template><Child :car="car" @send-value="sendValue"/>
</template>
<script setup lang="ts">
import {ref} from 'vue'
import Child from './Child.vue'
let car = ref('宝马')
function sendValue(value) {car.value=value
}
</script>子组件接收 defineEmits
让后触发sendValue自定义事件,第二个参数就是传递的值
<template><div class="child">{{ car }}</div><div @click="emit('send-value','奔驰')">点击</div>
</template>
<script setup lang="ts">
let refValue = defineProps(['car'])
let emit = defineEmits(['send-value'])
console.log(refValue.car)
</script>

4、mitt方式

实现任意通信
打包后包体积很小200byte

import mitt from 'mitt'
const emitter = mitt()绑定
emitter.on('test1',(v)=>{接收值})
emitter.on('test2',(v)=>{接收值})触发
emitter.emit('test1','值')
emitter.emit('test2','值')解绑
onUnMounted的时候去解绑
emitter.off('test1')
emitter.off('test2')

v-model

虽然实际开发部会自己用
当是组件库底层,在大量使用

<input type="text" :value="name" 
@input="name=$event.target.value"

参考连接,学了一半,没时间了
https://www.bilibili.com/video/BV1Za4y1r7KE?p=55&vd_source=705343a89f38d5c0d895383ccf38a5d6

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

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

相关文章

算法简单试题

一、选择题 01.一个算法应该是( B ). A.程序 B.问题求解步骤的描述 C.要满足五个基本特性 D.A和C 02&#xff0e;某算法的时间复杂度为O(n)&#xff0c;则表示该…

Python学习日记(二:函数和逻辑操作)

概述&#xff1a; 函数和逻辑操作在python中的地位是非常重要的&#xff0c;当然不只是在python中&#xff0c;几乎每一门编程语言都会用到这两样&#xff0c;所以打好基础对我们以后的学习非常重要&#xff0c;Python中的函数有很多都是已经封装好的&#xff0c;我们可以自己…

【C++实战项目】Date日期类 --- 运算符重载的深入探索

&#x1f4f7; 江池俊&#xff1a;个人主页 &#x1f525; 个人专栏&#xff1a;✅C那些事儿 ✅Linux技术宝典 &#x1f305; 此去关山万里&#xff0c;定不负云起之望 文章目录 引言一、为什么需要运算符重载&#xff1f;二、日期类的实现1. 基本框架2. 预备工作3. Date 类…

JimuReport积木报表 v1.7.1 版本发布,低代码报表工具

项目介绍 一款免费的数据可视化报表&#xff0c;含报表和大屏设计&#xff0c;像搭建积木一样在线设计报表&#xff01;功能涵盖&#xff0c;数据报表、打印设计、图表报表、大屏设计等&#xff01; Web 版报表设计器&#xff0c;类似于excel操作风格&#xff0c;通过拖拽完成报…

Qt应用软件【文件篇】读写文件技巧

文章目录 简介按照偏移读文件按照偏移写文件Qt按行写文件Qt按行读文件注意事项指定文件编码格式UTF8转GBK简介 Qt提供了丰富的API来处理文件读写操作,使得读写文件变得简单。 按照偏移读文件 QFile file("example.txt"); if (file.open(QIODevice::ReadOnly)) {q…

2024年冲刺年薪40w,Android岗面试

一个程序员&#xff0c;如果不想35 岁被淘汰&#xff0c;请把它当成一种信仰&#xff01; 25岁&#xff0c;一个北漂程序员&#xff0c;入职三年&#xff0c;Android中级工程师&#xff0c;月薪15k&#xff0c;965的工作经常干成996&#xff0c;比起老家的同龄人&#xff0c;我…

Thinkphp 6 - 数据库事务、分布式事务、模型使用事务、跨数据库事务(详细的使用实例,可直接复制用于您的项目中去)

一、简单的事务&#xff0c;单个数据库 /*** 普通事务* return json*/ public function demo01(){// 开启事务Db::startTrans();try{// 添加数据Db::table(article) -> insert([title > 测试事务]);Db::commit();return json([error_code > 0,msg > success]);}ca…

跨界电商、游戏技与代理IP的关联

在当今数字化时代&#xff0c;跨界电商与游戏技术的迅速发展为商业与娱乐带来了无限可能。然而&#xff0c;随着互联网的普及&#xff0c;网络安全问题也日益突出。在这个背景下&#xff0c;我们不得不重新审视代理IP与出海、socks5代理等技术之间的联系&#xff0c;以及它们对…

掘根宝典之C语言文件操作(fgetc,fputc,fscanf,fprintf,fread,fwrite,feek,ftell,fwind,feof)

1. 为什么使⽤⽂件&#xff1f; 如果没有⽂件&#xff0c;我们写的程序的数据是存储在电脑的内存中&#xff0c;如果程序退出&#xff0c;内存回收&#xff0c;数据就丢失 了&#xff0c;等再次运⾏程序&#xff0c;是看不到上次程序的数据的&#xff0c;如果要将数据进⾏持久…

【C/C++】结构体内存对齐 ----- 面试必考(超详细解析,小白一看就懂!!!)

目录 一、前言 二、引出 ---- 结构体内存对齐 &#x1f34e;结构体偏移量计算&#xff1a;offsetof &#x1f95d;结构体内存对齐详解 &#x1f4a6;规则介绍&#xff08;重点&#xff01;&#xff01;&#xff09; &#x1f4a6;例题解析 三、习题演练 &#x1f34d;练习① …

Spring Cloud 面试题及答案整理,最新面试题

Spring Cloud中断路器的原理及其作用是什么&#xff1f; Spring Cloud断路器的原理和作用基于以下几个关键点&#xff1a; 1、故障隔离机制&#xff1a; 在微服务架构中&#xff0c;断路器作为一种故障隔离机制&#xff0c;当某个服务实例出现问题时&#xff0c;断路器会“断…

Docker知识点总结二

四、 Docker 架构 Docker使用客户端-服务器(C/S)架构模式&#xff0c;使用远程API来管理和创建Docker容器。 介绍&#xff1a; 1、Docker的客户端client&#xff0c;我们在命令行发送一些信息(命令)给Docker服务端。2、中间这个就是Docker的服务端&#xff0c;在这个服务端里面…

漫步者、南卡、Cleer开放式耳机怎么样?硬核对比测评性能强者!

​在当今市场上&#xff0c;开放式耳机的型号层出不穷&#xff0c;作为一名专业的测评博主&#xff0c;我对这类产品有着深入的了解和丰富的经验。最近&#xff0c;我的粉丝们通过私信向我咨询如何选择适合自己的开放式耳机&#xff0c;面对众多品牌的选择&#xff0c;他们感到…

【Unity】使用ScriptableObject存储数据

1.为什么要用ScriptableObject&#xff1f; 在游戏开发中&#xff0c;有大量的配置数据需要存储&#xff0c;这个时候就需要ScriptableObject来存储数据了。 很多人会说我可以用json、xml、txt&#xff0c;excel等等 但是你们有没有想过&#xff0c;假设你使用的是json&#x…

【Linux基础(一)】设备和文件IO

学习分享 1、Linux中的设备管理1.1、设备管理的特点1.2、设备分类1.3、设备工作原理1.4、Linux设备操作1.5、系统调用和系统API等区别 2、文件IO2.1、C库的文件操作2.2、文件描述符2.3、特殊文件描述符2.4、系统调用2.4.1、open系统调用4-12.4.2、open系统调用4-22.4.3、write系…

每日一题 2917找出数组中的K-OR值

2917. 找出数组中的 K-or 值 题目描述&#xff1a; 给你一个下标从 0 开始的整数数组 nums 和一个整数 k 。 nums 中的 K-or 是一个满足以下条件的非负整数&#xff1a; 只有在 nums 中&#xff0c;至少存在 k 个元素的第 i 位值为 1 &#xff0c;那么 K-or 中的第 i 位的值…

爬虫实战——伯克利新闻【内附超详细教程,你上你也行】

文章目录 发现宝藏一、 目标二、简单分析网页1. 寻找所有新闻2. 分析模块、版面和文章 三、爬取新闻1. 爬取模块2. 爬取版面3. 爬取文章 四、完整代码五、效果展示 发现宝藏 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不…

2023年扫地机器人行业分析报告(2024年扫地机器人行业未来趋势分析)

当前&#xff0c;随着人们生活水平的提高&#xff0c;扫地机器人因为操作简单、使用方便而越来越多地走入了人们的生活&#xff0c;成为清洁电器中的重要一员&#xff0c;深受消费者欢迎。 伴随科技水平的进步&#xff0c;当前的扫地机器人已经具备了高度智能化的功能&#xf…

C++_位图

目录 1、位图的使用 2、位图实现 3、位图与哈希表的区别 4、位图的应用 结语 前言&#xff1a; 位图采用的是哈希表的思想&#xff0c;哈希表的映射层面是在字节上&#xff0c;而位图的映射层面就是在bit位上。由于bit位所能展现的信息无非只有‘1’和‘0’&#xff0c;所…

【Apple Vision Pro应用源码】Vision Pro吸尘器项目源代码

超级有趣Vision Pro 应用 吸尘器项目 这是一个非常有趣的 Vision Pro项目&#xff0c;会让孩子们爱上打扫卫生。 在这里我展示了如何使用 ARKit&#xff1a;头部跟踪、手部跟踪、场景理解加载和播放声音进程冲突使用 MTLBuffers 处理底层网格数据 项目源代码&#xff1a;Git…