阿西河

所有教程

公众号
🌙
阿西河前端的公众号

我的收藏

    最近访问  (文章)

      教程列表

      抓包专区
      测试专区

      Vue.js 组件如何通信以及有哪些方式?

      问题

      Vue组件如何通信以及有哪些方式?

      单向数据流

      答案

      • 父子间通信 父->子通过props、子-> 父$on、$emit
      • 获取父子组件实例的方式$parent、$children
      • 在父组件中提供数据子组件进行消费 Provide、inject
      • Ref获取实例的方式调用组件的属性或者方法
      • Event Bus 实现跨组件通信
      • Vuex状态管理实现通信

      1. ⽗⼦通信

      ⽗组件通过 props 传递数据给⼦组件,⼦组件通过 emit 发送事件传递数据给⽗组件, 这两种⽅式是最常⽤的⽗⼦通信实现办法。

      这种⽗⼦通信⽅式也就是典型的单向数据流,⽗组件通过 props 传递数据,⼦组件不能 直接修改 props ,⽽是必须通过发送事件的⽅式告知⽗组件修改数据。

      另外这两种⽅式还可以使⽤语法糖 v-model 来直接实现,因为 v-model 默认会解析成 名为 value 的 prop 和名为 input 的事件。这种语法糖的⽅式是典型的双向绑定, 常⽤于 UI 控件上,但是究其根本,还是通过事件的⽅法让⽗组件修改数据。

      当然我们还可以通过访问 $parent 或者 $children 对象来访问组件实例中的⽅法和数 据。

      另外如果你使⽤ Vue 2.3 及以上版本的话还可以使⽤ $listeners 和 .sync 这两个属 性。

      $listeners 属性会将⽗组件中的 (不含 .native 修饰器的) v-on 事件监听器传递给 ⼦组件,⼦组件可以通过访问 $listeners 来⾃定义监听器。

      .sync 属性是个语法糖,可以很简单的实现⼦组件与⽗组件通信

      <!--⽗组件中-->
      <input :value.sync="value" />
      <!--以上写法等同于-->
      <input :value="value" @update:value="v => value = v"></comp>
      <!--⼦组件中-->
      <script>
      this.$emit('update:value', 1)
      </script>
      

      2. 兄弟组件通信

      对于这种情况可以通过查找⽗组件中的⼦组件实现,也就是 this.$parent.$children ,在 $children 中可以通过组件 name 查询 到需要的组件实例,然后进⾏通信。

      3. 跨多层次组件通信

      对于这种情况可以使⽤ Vue 2.2 新增的 API provide / inject ,虽然⽂ 档中不推荐直接使⽤在业务中,但是如果⽤得好的话还是很有⽤的。

      假设有⽗组件 A ,然后有⼀个跨多层级的⼦组件 B

      // ⽗组件 A
      export default {
          provide: {
              data: 1
          }
      }
      // ⼦组件 B
      export default {
          inject: ['data'],
          mounted() {
              // ⽆论跨⼏层都能获得⽗组件的 data 属性
              console.log(this.data) // => 1
          }
      }
      

      终极办法解决⼀切通信问题

      只要你不怕麻烦,可以使⽤ Vuex 或者 Event Bus 解决上述所有的通信情 况。

      扩展:

      以前博客里也有总结这个问题

      https://www.axihe.com/anbang/blog/vue/vue-component-communication.html

      更多面试题

      如果你想了解更多的前端面试题,可以查看本站的WEB前端面试题 ,这里基本包涵了市场上的所有前端方面的面试题,也有一些大公司的面试图,可以让你面试更加顺利。

      面试题
      HTMLCSSJavaScript
      jQueryVue.jsReact
      算法HTTPBabel
      BootStrapElectronGulp
      Node.js前端经验相关前端综合
      Webpack微信小程序-

      这些题库还在更新中,如果你有不错的面试题库欢迎分享给我,我整理后放上来;人人为我,我为人人,互帮互助,共同提高,祝大家都拿到心仪的Offer!

      目录
      目录