vue快速入门(三十六)组件通信-子传父

注释很详细,直接上代码

上一篇

新增内容

  1. 子传父之子组件传递方法与值
  2. 子传父之父组件接收方法与值
    源码

App.vue

html 复制代码
<template>
  <div id="app">
    <!-- @事件名="方法" 接收子组件传递过来的方法,
      可在方法中使用子组件传递的值 -->
    <MyTest :counts="counts" @addCount="addCount"/>
  </div>
</template>
<script>
// 导入局部注册组件
import MyTest from "./components/MyTest.vue";
export default {
  name: "App",
  components: {
    //注册局部注册组件
    MyTest,
  },
  data() {
    return {
      //定义data值
      counts:1000
    };
  },
  methods: {
    addCount(num){//使用子组件传递过来的值进行操作
      this.counts+=num;
    }
  },
};
</script>
<style>
#app {
  display: flex;
  flex-direction: row;
}
</style>

MyTest.vue

html 复制代码
<template>
    <div id="MyTest">
        
       <h1>当前功德数:{{ counts }}</h1>
       <div>
        <!-- @click="$emit(事件名',传的数据) ,向父组件发送事件并传值" -->
       <button v-for="(item) in num" @click="$emit('addCount',item)" :key="item">敲木鱼{{ item }}次</button>
       </div>
    </div>
</template>

<script>
    export default {
        // 因为组件每次使用都需要是一个新的对象,
        // 所以data数据都需要是函数返回
        data() {
            return {
                num:[1,10,100]
            }
        },
        // 接收父组件传过来的数据
        props:['counts']
    }
</script>

<style lang="less" scoped>
#MyTest button{
    margin: 0 10px;
}

</style>

效果演示

相关推荐
踩着两条虫6 分钟前
VTJ:应用场景展示
前端·vue.js·架构
夜宵饽饽7 分钟前
Agent文件系统检索核心:Grep和Glob工具
javascript·github
Ruihong22 分钟前
Vue v-slot → 用 VuReact 转换后变成这样的 React 代码
vue.js·react.js·面试
Ruihong23 分钟前
你的 Vue v-model,VuReact 会编译成什么样的 React 代码?
vue.js·react.js·面试
Cobyte1 小时前
6.响应式系统比对:通过 Vue3 响应式库写 React 应用
前端·javascript·vue.js
我不是懒洋洋1 小时前
【经典题目】栈和队列面试题(括号匹配问题、用队列实现栈、设计循环队列、用栈实现队列)
c语言·开发语言·数据结构·算法·leetcode·链表·ecmascript
云浪1 小时前
从 0 到 1 搭建 RAG 应用:用 LangChain + Chroma + qwen-plus 实现《红楼梦》问答
javascript·vue.js·人工智能
xiaoxue..1 小时前
react:浅聊 vdom 与 diff 算法
前端·javascript·react.js·面试
止语Lab1 小时前
记忆溢出:当你的 Agent 记得太多时会发生什么
前端·javascript·vue.js
天天向上10242 小时前
vue openlayers地图加载大量点位时优化
前端·javascript·vue.js