组件通信
组件通信一般分为以下几种情况:
- 父子组件通信
- 兄弟组件通信
- 任意组件
父子通信
父组件通过 props 传递数据给子组件,子组件通过 emit 发送事件传递数据给父组件,这两种方式是最常用的父子通信实现办法。
这种父子通信方式也就是典型的单向数据流,父组件通过 props 传递数据,子组件不能直接修改 props, 而是必须通过发送事件的方式告知父组件修改数据。
另外这两种方式还可以使用语法糖 v-model 来直接实现,因为 v-model 默认会解析成名为 value 的 prop 和名为 input 的事件。这种语法糖的方式是典型的双向绑定,常用于 UI 控件上,但是究其根本,还是通过事件的方法让父组件修改数据。
兄弟组件通信
对于这种情况可以通过查找父组件中的子组件实现,也就是 this.$ parent.$ children,在 $children 中可以通过组件 name 查询到需要的组件实例,然后进行通信。
任意组件
这种方式可以通过 Vuex 或者 $Bus 解决,另外如果你不怕麻烦的话,可以使用这种方式解决上述所有的通信情况