vue3中的组件通信

server/2024/11/15 4:38:47/

props通信

可以实现父子组件通信,props数据还是只读的!!!

javascript"><template><div class="box"><h1>props:我是父组件曹操</h1><hr /><Child info="我是曹操" :money="money"></Child></div>
</template><script setup lang="ts">
//props:可以实现父子组件通信,props数据还是只读的!!!
import Child from "./Child.vue";
import { ref } from "vue";
let money = ref(10000);
</script><style scoped>
.box {width: 100vw;height: 400px;background: yellowgreen;
}
</style>
javascript"><template><div class="son"><h1>我是子组件:曹植</h1><p>{{ props.info }}</p><p>{{ props.money }}</p><!--props可以省略前面的名字---><p>{{ info }}</p><p>{{ money }}</p><button @click="updateProps">修改props数据</button></div>
</template><script setup lang="ts">
//需要使用到defineProps方法去接受父组件传递过来的数据
//defineProps是Vue3提供方法,不需要引入直接使用
let props = defineProps(["info", "money"]); //数组|对象写法都可以
// let props = defineProps({
//   info:{
//    type:String,//接受的数据类型
//    default:'默认参数',//接受默认数据
//   },
//   money:{
//    type:Number,
//    default:0
// }}); // 对象写法
// 这里的props只是一个代理项,在模板中使用时是可以省略的。
//按钮点击的回调
const updateProps = () => {// props.money+=10;  props:只读的console.log(props.info);
};
</script><!-- <script>
export default {props: ["info", "money"]
};
// 这里是vue2选择式api的写法,vue3都用上面那个组合式api的写法。
</script> --><style scoped>
.son {width: 400px;height: 200px;background: hotpink;
}
</style>

自定义事件

javascript"><template><div><h1>事件</h1><!-- 原生DOM事件 --><pre @click="handler">大江东去浪淘尽,千古分流人物</pre><button @click="handler1(1, 2, 3, $event)">点击我传递多个参数</button><hr /><!--vue2框架当中:这种写法自定义事件,可以通过.native修饰符变为原生DOM事件vue3框架下面写法其实即为原生DOM事件vue3:原生的DOM事件不管是放在标签身上、组件标签身上都是原生DOM事件--><Event1 @click="handler2"></Event1><hr /><!-- 绑定自定义事件xxx:实现子组件给父组件传递数据 --><Event2 @xxx="handler3" @click="handler4"></Event2></div>
</template><script setup lang="ts">
//引入子组件
import Event1 from "./Event1.vue";
//引入子组件
import Event2 from "./Event2.vue";
//事件回调--1
const handler = event => {// 原生DOM事件,会向事件回调注入事件对象//默认就是event,即为事件对象console.log(event);
};
//事件回调--2
const handler1 = (a, b, c, $event) => {console.log(a, b, c, $event);
};
//事件回调---3
const handler2 = () => {console.log(123);
};
//事件回调---4
const handler3 = (param1, param2) => {console.log(param1, param2);
};
//事件回调--5
const handler4 = (param1, param2) => {console.log(param1, param2);// alert("123");
};
</script><style scoped></style>
javascript"><template><div class="son"><p>我是子组件1</p><button>点击我也执行</button></div>
</template><script setup lang="ts"></script><style scoped>
.son{width: 400px;height: 200px;background: skyblue;
}
</style>
javascript"><template><div class="child"><p>我是子组件2</p><button @click="handler">点击我触发自定义事件xxx</button><button @click="$emit('click', 'AK47', 'J20')">点击我触发自定义事件click</button></div>
</template><script setup lang="ts">
//利用defineEmits方法返回函数触发自定义事件
//defineEmits方法不需要引入直接使用
let $emit = defineEmits(["xxx", "click"]);
//按钮点击回调
const handler = () => {//第一个参数:事件类型 第二个|三个|N参数即为注入数据$emit("xxx", "东风导弹", "航母");
};
</script><style scoped>
.child {width: 400px;height: 200px;background: pink;
}
</style>

在vue框架中,事件分为两种:原生的DOM事件,自定义事件。
原生的DOM事件可以让用户与网页进行交互,比如:click、dbclick、change、mouseenter、mouseleave…
自定义事件可以实现子组件给父组件传递数据。

原生DOM事件

javascript"><pre @click="handler">我是祖国的老花骨朵</pre><div @click="handler1(1,2,3,$event)">我要传递多个参数</div>

当前代码级给pre标签绑定原生DOM事件点击事件,默认会给事件回调注入event事件对象。点击事件也可以注入多个参数。
**切记:**注入的事件对象务必叫做$event。
在vue3框架中,click、dbclick、change(这类原生DOM事件),不管是在标签、自定义标签上(组件标签)都是原生DOM事件。
但在vue2中,组件标签需要通过.native修饰符才能变为原生DOM事件。


http://www.ppmy.cn/server/104098.html

相关文章

jenkins 发布镜像清理

概述 我们在使用jenkins执行build命令时&#xff0c;偶尔会产生一些版本为none的镜像&#xff0c;但是这些镜像是完全没有用的&#xff0c;占用了磁盘空间&#xff0c;需要定期清理。 脚本清理 编辑脚本clean_docker_image.sh #!/bin/bash # docker删除none镜像 docker rmi $(d…

Leetcode JAVA刷刷站(69)x的平方根

一、题目概述 二、思路方向 在Java中&#xff0c;计算一个非负整数x的算术平方根&#xff0c;并返回其整数部分&#xff0c;你可以使用二分查找法。这是因为平方根函数是单调递增的&#xff0c;所以我们可以利用二分查找在合理的时间复杂度内找到结果。 三、代码实现 public…

【设计模式】构造器模式和原型模式

构造器模式 如果我们系统中有多个员工&#xff0c;创建每一个员工都需要 new 一下&#xff0c;出现很多重复代码&#xff0c;所以我们可以将他们写成一个构造函数&#xff0c;然后通过传入的不同参数创建不同的员工。 function Employee(name, age) {this.name namethis.age…

leetcode 26 删除有序数组中的重复项

正文 本题使用双指针解法即可&#xff0c;右指针移动&#xff0c;若右指针所指向元素与左指针指向元素一致&#xff0c;右侧指针继续右移&#xff0c;若右指针指向元素与做左指针指向元素不一致&#xff0c;左指针位置 1&#xff0c;且令左指针处元素等于右指针处元素。 class…

使用docker compose一键部署 Portainer

使用docker compose一键部署 Portainer Portainer 是一款轻量级的应用&#xff0c;它提供了图形化界面&#xff0c;用于方便地管理Docker环境&#xff0c;包括单机环境和集群环境。 1、创建安装目录 mkdir /data/partainer/ -p && cd /data/partainer2、创建docker…

LeetCode216 组合总和 III

前言 题目&#xff1a; 216. 组合总和 III 文档&#xff1a; 代码随想录——组合总和 III 编程语言&#xff1a; C 解题状态&#xff1a; 成功解答 思路 组合题的变种&#xff0c;其实是变得更简单了&#xff0c;还是可以使用回溯法来解决。 代码 回溯法 class Solution { …

Windows All download

前言 微软家族产品下载HEU_KMS_Activator download Windows PC desktop download 微软官网all 地址&#xff0c;地址1国内镜像地址&#xff0c;地址1 Windows 常规使用&#xff0c;运维&#xff0c;部署csdn 专栏 &#xff0c;付费专栏 参考 版本微软官网Windows 7,8,10,…

通过电影之镜,提升生活之美

在快节奏的现代生活中&#xff0c;电影不仅是娱乐的载体&#xff0c;更是提升审美情趣、拓宽视野的窗口。三部各具特色的经典之作——《布达佩斯大饭店》、《花样年华》与《天使爱美丽》&#xff0c;以其独特的视觉风格、深刻的情感表达与细腻的艺术构思&#xff0c;为我们展示…