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和jsonp跨域的原理本质详解 2023-02-14
- layui的弹出框msg修改字体按钮样式 2022-10-21
- 「免费开源」基于Vue和Quasar的前端SPA项目crudapi后台管理系统实战之docker部署(八) 2023-10-08
- Js参数值中含有单引号或双引号问题的解决方法 2024-01-08
- 用Flutter做桌上弹球(绘图(Canvas&CustomPaint)API) 2024-01-04
- 用一个DIV画图通过background-image叠加实现 2024-04-08
- Vue定义一个路由需要几步? 2025-01-16
- uni-app如何实现点击按钮全屏播放视频 2023-08-29
- 高效利用Angular中内置服务$http、$location等 2024-02-09
- Bootstrap栅格系统的使用和理解2 2024-01-24