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如何实现父子组件相互通信


基础教程推荐
猜你喜欢
- Vue定义一个路由需要几步? 2025-01-13
- 前端面试复盘:vue技术面没有难倒我,hr面却是一把挂 2023-10-08
- Ajax+php实现商品分类三级联动 2023-01-20
- 基于JQuery的cookie插件 2024-02-13
- Window.Open打开窗体和if嵌套代码 2023-12-21
- Ajax对缓存的处理方法实例分析 2023-02-23
- Ajax提交表单页面刷新很快的解决方法 2023-01-26
- 微信小程序 自己制作小组件实例详解 2023-12-19
- css弧边选项卡的项目实践 2024-02-09
- html清除浮动的6种方法示例 2024-01-24