vuejs如何实现父子组件相互通信,下面编程教程网给大家详细介绍一下实现代码!
App.vue组件
<template>
<div class="app">
<h2>当前计数:{{counter}}</h2>
<!-- 1.自定义add-counter 并且监听内部的add事件 -->
<add-counter @add="addBtnClick"></add-counter>
<!-- 2.自定义su-counter组件,监听内部的sub事件 -->
<sub-counter @sub="subBtnClick"></sub-counter>
</div>
</template>
<script>
import AddCounter from './AddCounter.vue'
import SubCounter from './SubCounter.vue'
export default {
components: {
AddCounter,
SubCounter
},
data() {
return {
counter:0
}
},
methods:{
addBtnClick(count) {
this.counter += count
},
subBtnClick(count) {
this.counter -= count
}
}
}
</script>
AddCounter子组件
<template>
<div class="add">
<button @click="btnClick(1)">+1</button>
<button @click="btnClick(5)">+5</button>
<button @click="btnClick(10)">+10</button>
</div>
</template>
<script>
export default {
methods:{
btnClick(count) {
// 让子组件发出去一个自定义事件
// 第一个参数自定义的事件名称,第二个参数是传递的参数
this.$emit("add",count)
}
}
}
</script>
SubCounter子组件
<template>
<div class="sub">
<button @click="btnClick(1)">-1</button>
<button @click="btnClick(5)">-5</button>
<button @click="btnClick(10)">-10</button>
</div>
</template>
<script>
export default {
emits:["addd"],
methods:{
btnClick(count) {
this.$emit("sub",count)
}
}
}
</script>
子组件事件触发之后,通过this.$emit
的方式进行发出事件!
沃梦达教程
本文标题为:vuejs如何实现父子组件相互通信


猜你喜欢
- Ajax入门学习教程(一) 2023-01-26
- 小区后台管理系统项目前端html页面模板实现示例 2022-11-20
- HTML标签(上) 2023-10-27
- HTML中Pre标签 2023-10-27
- vuejs用window.open打开base64图片 2024-12-07
- vue+oss 纯前端文件上传 2023-10-08
- js实现广告漂浮效果的小例子 2024-02-05
- 鼠标悬停图片产生边框的效果实现 2024-01-03
- vue项目利用WebSocket插件实现在线聊天功能 2025-01-13
- input submit、button和回车键提交数据详解 2022-11-13