前端经典面试题 | Vue组件间的通信方式

简介: 前端经典面试题 | Vue组件间的通信方式

一、回答点

普遍的 说 三四个即可 父/子 props/emit eventBus  provide/ inject 等..

二、深入回答

props/$emit

       简述: 父组件通过 props 向子组件传递数据,子组件通过 $emit 和父组件通信


父组件向子组件传值


  • props 只能由父组件对子组件进行传值, 使得父子组件之间形成一个单向绑定.子组件的数据会随着父组件不断的更新
  • props 可以定义一个以上(包括一个)的数据,对于子组件接收的数据,可以是各种数据类型,也可以传递一个函数
  • 代码展示
<!-- 父组件 -->
<template>
  <div class="father">
    <son :msg="msg" :fn="fatherFunction" />
  </div>
</template>
<script>
import son from './sons.vue'
export default {
  name: 'FatherPage',
  components: {
    son
  },
  data() {
    return {
      msg: '父组件数据'
    }
  },
  methods: {
    fatherFunction() {
      console.log('fatherPage')
    }
  }
}
</script>
<!-- 子组件 -->
<template>
  <div class="son">
    <p>父组件传递过来的值:{{ msg }}</p>
    <button @click="fn">按钮</button>
  </div>
</template>
<script>
export default {
  name: 'Son',
  props: ['msg', 'fn']
}
</script>

子组件向父组件传值


  • $emit 绑定一个自定义事件,当这个事件被触发时会将参数传递给父组件 而父组件通过 v-on 或语法糖(@) 监听并接收参数
  • 代码展示
<!-- 父组件 -->
<template>
  <div class="father">
    <son @clickSon="clickSonMsg" />
  </div>
</template>
<script>
import son from './sons.vue'
export default {
  name: 'FatherPage',
  components: {
    son
  },
  methods: {
    clickSonMsg() {
      console.log('子组件传递过来点击信息')
    }
  }
}
</script>
<!-- 子组件 -->
<template>
  <div class="son">
    <button @click="sonClick">告诉父亲被打了!</button>
  </div>
</template>
<script>
export default {
  name: 'SonPage',
  methods: {
    sonClick() {
      this.$emit('clickSonMsg')
    }
  }
}
</script>

eventBus 事件总线(emit/emit/emit/on)

       简述:eventBus事件总线 适合 父子组件|非父子组件等之间的通信,使用步骤如下:


  • 创建事件中心管理组件之间的通信
  • 发送事件
  • 接收事件

依赖注入Provide / inject

       简述: Vue中的依赖注入,用于 父子组件之间通信,也可用于 祖孙组件之间的通信,在层级很深的情况下,使用这种方式进行传值.


provide / inject 是Vue提供的两个钩子函数 和 data methods 是同级的 并且 provide书写跟data是一样的.


  • provide 是用来发送数据/方法
  • inject 用来接收数据/方法
  • 需要注意的是 依赖注入提供的属性 都 不是响应式
  • 代码展示
// 在父组件中:
  provide() {
    return {
      num: this.num
    }
  }
// 在子组件中:
  inject: ['num']

ref/$refs

       简述:也是实现 父子组件 之间的通信


  • ref:用在子组件上,它的引用指向了子组件的实例. 可以通过实例来访问组件的数据和方法..

parent/parent/parent/ children

  • $parent 可以让组件访问父组件的实例(上一级组件的属性和方法)
  • $children 可以让组件访问子组件的实例,注: 它并不能保证 子组件的顺序,并且访问的数据 不是响应式数据

attrs/attrs/attrs/listeners

       简述: Vue引入了它们两个 可以实现 跨组件跨代通信


  • $attrs: 继承所有的父组件属性(除了prop传递的属性 class style),常用于 子组件的元素上
  • listeners:,,von=listeners:它是一个对象,包含了作用在这个组件上的所有监听器,配合v−on=listeners: 它是一个对象,包含了 作用在这个组件上的所有监听器,配合v-on=listeners,将所有的事件监听器指向这个组件的某个特定的元素.

三、总结及归纳

父子组件的通信

  • 子组件通过 props 来接收父组件传递过来的数据, 父组件在子组件上 注册监听事件,子组件通过 $emit触发事件 向 父组件发送数据.
  • 通过ref属性给子组件设置名字,父组件通过refs=,refs=组件名来获取子组件实例,子组件通过refs=组件名来获取子组件实例,子组件通过parent获得父组件,这样也可以实现通信.
  • 使用provide/inject , 在父组件中 通过 provide提供变量, 子组件中通过inject将变量注入到组件中,不论层级有多深,只要调用了inject 就可以注入 provide中的数据

兄弟组件的通信

  • eventBus方法,它本质是通过 创建一个空的Vue实例来作为消息传递的对象, 通信组件 引入这个实例,通过这个实例来监听和触发时间,实现传递
  • 通过parent/parent/parent/refs 来获取到兄弟组件 也可以进行通信

任意组件之间

  • 还是通过eventBus来实现,他创建了一个 中心点 可以用它来传递事件和接收
相关文章
|
2月前
|
监控 前端开发 数据可视化
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
@icraft/player-react 是 iCraft Editor 推出的 React 组件库,旨在简化3D数字孪生场景的前端集成。它支持零配置快速接入、自定义插件、丰富的事件和方法、动画控制及实时数据接入,帮助开发者轻松实现3D场景与React项目的无缝融合。
197 8
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
|
2月前
|
前端开发 JavaScript 开发者
React与Vue:前端框架的巅峰对决与选择策略
【10月更文挑战第23天】React与Vue:前端框架的巅峰对决与选择策略
|
2月前
|
前端开发 JavaScript 数据管理
React与Vue:两大前端框架的较量与选择策略
【10月更文挑战第23天】React与Vue:两大前端框架的较量与选择策略
|
2月前
|
前端开发 JavaScript 开发者
揭秘前端高手的秘密武器:深度解析递归组件与动态组件的奥妙,让你代码效率翻倍!
【10月更文挑战第23天】在Web开发中,组件化已成为主流。本文深入探讨了递归组件与动态组件的概念、应用及实现方式。递归组件通过在组件内部调用自身,适用于处理层级结构数据,如菜单和树形控件。动态组件则根据数据变化动态切换组件显示,适用于不同业务逻辑下的组件展示。通过示例,展示了这两种组件的实现方法及其在实际开发中的应用价值。
48 1
|
2月前
|
JavaScript 前端开发 搜索推荐
Vue的数据驱动视图与其他前端框架的数据驱动方式有何不同?
总的来说,Vue 的数据驱动视图在诸多方面展现出独特的优势,其与其他前端框架的数据驱动方式的不同之处主要体现在绑定方式、性能表现、触发机制、组件化结合、灵活性、语法表达以及与后端数据交互等方面。这些差异使得 Vue 在前端开发领域具有独特的地位和价值。
|
2月前
|
前端开发 JavaScript 开发者
React与Vue:前端框架的巅峰对决与选择策略
【10月更文挑战第23天】 React与Vue:前端框架的巅峰对决与选择策略
|
缓存 监控 JavaScript
vue面试中常见的面试题
vue面试中常见的面试题
1499 0
vue面试中常见的面试题
|
9天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
67 1
|
20天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
2月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
50 1
vue学习第一章

热门文章

最新文章

下一篇
开通oss服务