Vue 的父子通信【props、$emit】

简介: vue中通信方式有很多,vuex,父子通信,兄弟通信,祖代通信等。但是最常用的就是vuex和父子通信。vue讲组件化,组件化的封装父子通信必须要会。这篇文章适合小白参考。喜欢点赞哦~

vue中父子通信是常用到的技术点,有多种方法可以进行传值,复杂的传值方式去参考vueX。今天我们简单说下常用的2种方式:

父传子:props传值
子传父:$emit

1. ----------父传子----------

父组件给子组件传值,需要在子组件中添加props进行接收父组件传来的值

父组件:
随便封装一个子组件,起名叫childComponent。给引入的子组件中传一个“我是父组件”,随便定义一个hello接收。

<!-- 父组件-->

<template>
  <div class="aaa">
  
    <childComponent hello="我是父组件"></childComponent>
    
  </div>
</template>
<script>
// 引入子组件
import childComponent from "/components/childComponent.vue";
export default {
  data() {
    return {};
  },
  components: {
    // 要在components中注册子组件才能使用
    childComponent
  },
  methods: {}
};
</script>
<style scoped></style>

子组件:
div中的hello会显示“我是父组件”,这是从父组件通过props传过来的

<!-- 子组件-->
<template>
  <div class="aaa">
    
    <div>{{ hello }}</div>
    
  </div>
</template>
<script>
export default {
  data() {
    return {
      // 因为props中接收了hello属性,所以data中不能再定义相同的hello属性。
    };
  },
  // props 中接收在父组件中定义的hello
  props: {
    hello: {
      type: String // 在hello中加入了type:String,是告诉其他人,hello只接收字符串内容,传其他的会报错。这样对于团队合作更严谨。当然可以什么都不加,直接写hello。
    }
  }
};
</script>
<style scoped></style>

这样子组件在页面上就会显示“我是父组件”这句话了,当然,这个值可以动态绑定,传递你想要传递的值,也可以传递布尔值,数组等信息。

2.----------子传父 $emit----------

this.$emit(‘要触发的方法’,参数)

我们随便定义一个要触发的方法,叫 aaa,然后传一个 123 的参数给父组件

<!-- 子组件-->
<template>
  <div class="aaa">
    <button @click="handleClick">子组件</button>
  </div>
</template>
<script>
export default {
  data() {
    return {};
  },
  methods: {
    // 点击按钮上边button按钮,调用这个handleClick方法,通过$emit触发aaa,把 123 传过去。父组件通过 aaa 接收这个值。(往下看父组件中的内容)。
    handleClick() {
      this.$emit("aaa", 123);
    }
  }
};
</script>
<style scoped></style>

父组件:

父组件中引入的子组件里,放入刚才通过$emit触发的方法 aaa,然后随便定义一个方法 getChildData ,它的值就是传递过来的123

<!-- 父组件-->

<template>
  <div class="aaa">
    <childComponent @aaa="getChildData"></childComponent>
  </div>
</template>
<script>
// 引入子组件
import childComponent from "/components/childComponent.vue";
export default {
  data() {
    return {};
  },
  components: {
    // 要在components中注册子组件才能使用
    childComponent
  },
  methods: {
    // aaa 接收到的属性,随便定义一个函数 getChildData 方法来接收
    getChildData(data) {
      console.log(data); // 这个data就是子组件传递过来的值 123
    }
  }
};
</script>
<style scoped></style>

仔细看代码,相信你会理解的父子通信的。那么兄弟组件之间也可以通信,是通过子传父,在父传子,这样就实现了子和子传递了,也就是兄弟通信,父组件作为中间的桥梁。除了这种方法,还可以用中央事件总线(bus)来进行传递,不过现在很少会用到bus来实现传递了。

目录
相关文章
|
10天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
67 1
|
20天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
2月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
存储 JavaScript 前端开发
介绍一下Vue的核心功能
介绍一下Vue的核心功能
|
JavaScript 测试技术 容器
Vue2+VueRouter2+webpack 构建项目
1). 安装Node环境和npm包管理工具 检测版本 node -v npm -v 图1.png 2). 安装vue-cli(vue脚手架) npm install -g vue-cli --registry=https://registry.
1067 0
|
2月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
51 1
vue学习第一章
|
2月前
|
JavaScript 前端开发 索引
vue学习第三章
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中的v-bind指令,包括基本使用、动态绑定class及style等,希望能为你的前端学习之路提供帮助。持续关注,更多精彩内容即将呈现!🎉🎉🎉
48 1
|
2月前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
41 1
vue学习第四章
|
2月前
|
JavaScript 前端开发 算法
vue学习第7章(循环)
欢迎来到瑞雨溪的博客,一名热爱JavaScript和Vue的大一学生。本文介绍了Vue中的v-for指令,包括遍历数组和对象、使用key以及数组的响应式方法等内容,并附有综合练习实例。关注我,将持续更新更多优质文章!🎉🎉🎉
34 1
vue学习第7章(循环)

热门文章

最新文章

下一篇
开通oss服务