父子组件之间的数据共享又分为
①父 -> 子共享数据
②子 -> 父共享数据

1、父组件向子组件共享数据

父组件向子组建共享数据需要使用自定义属性。事例代码如下:
父组件向子组件共享数据
子组件利用props自定义属性,父组件在调用子组件的时候使用这个自定义属性,并添加属性值,字组件就会接收到数据。
如果直接在子组件中修改prop,Vue会发出警告,因为prop属于单向数据流,即父级 prop 的更新会向下流动到子组件中,但是反过来则不行。这样会防止从子组件意外改变父级组件的状态,所以这里有两种常见的方法在子组件中修改prop传递的值。

方法一: 先在子组件的data中定义一个变量并把prop作为初始值 js

  • 本地定义一个变量,并将prop作为初始值
data: function () {
  return {
    message: this.msg
  • prop 以一种原始的值传入且需要进行转换,在computed中定义
computed: {
  normalizedSize: function () {
    return this.size.trim().toLowerCase()

注:Prop 的大小写 (camelCase vs kebab-case)
HTML 中的 attribute 名是大小写不敏感的,所以浏览器会把所有大写字符解释为小写字符。这意味着当你使用 DOM 中的模板时,camelCase (驼峰命名法) 的 prop 名需要使用其等价的 kebab-case (短横线分隔命名) 命名:

Vue.component('blog-post', {
  // 在 JavaScript 中是 camelCase 的
  props: ['postTitle'],
  template: '<h3>{{ postTitle }}</h3>'
<!--HTML 中是 kebab-case-->
<blog-post post-title="hello!"></blog-post>

重申一次,如果你使用字符串模板,那么这个限制就不存在了。
例如:在开发中子组件定义自定义属性为驼峰命名法,如:

tempSwitch: {
  type: Boolean,
  default: false

在父组件中使用此属性时为了方便区分,将使用短横线分隔命名:

:temp-switch="tempSwitch"

2、子组件向父组件共享数据

子组件向父组件共享数据使用自定义事件。示例代码如下:
子组件向父组件共享数据子组件是用$emit定义自定义事件的名称,并加上所要传递的值,父组件使用此事件,并在事件后面加上相应的函数方法,函数里面的传递的值,就是子组件要给父组件传递的值。

3、兄弟组件之间的数据共享

在 vue2.x 中,兄弟组件之间数据共享的方案是 EventBus
兄弟组件之间的数据共享
EventBus 的使用步骤:
① 创建 eventBus.js 模块,并向外共享一个 Vue 的实例对象
② 在数据发送方,调用 bus.$emit(‘事件名称’, 要发送的数据) 方法触发自定义事件
③ 在数据接收方,调用 bus.$on(‘事件名称’, 事件处理函数) 方法注册一个自定义事件

4、$parent 或$ root

通过共同祖辈$parent或者$root搭建通信桥连
兄弟组件

this.$parent.on('add',this.add)

另一个兄弟组件

this.$parent.emit('add')

5、$attrs 与$ listeners

  • 适用场景:祖先传递数据给子孙
  • 设置批量向下传属性$attrs$listeners
  • 包含了父级作用域中不作为 prop 被识别 (且获取) 的特性绑定 ( class 和 style 除外)。
  • 可以通过 v-bind="$attrs" 传⼊内部组件
// child:并未在props中声明foo  
<p>{{$attrs.foo}}</p>  
// parent  
<HelloWorld foo="foo"/>  
// 给Grandson隔代传值,communication/index.vue  
<Child2 msg="lalala" @some-event="onSomeEvent"></Child2>  
// Child2做展开  
<Grandson v-bind="$attrs" v-on="$listeners"></Grandson>  
// Grandson使⽤  
<div @click="$emit('some-event', 'msg from grandson')">  
{{msg}}  
</div>  

6、provide 与 inject

  • 在祖先组件定义provide属性,返回传递的值
  • 在后代组件通过inject接收组件传递过来的值

祖先组件:

provide(){  
  return {  
    foo:'foo'  

后代组件:

inject:['foo'] // 获取到祖先组件传递过来的值  

7、vuex

  • 适用场景: 复杂关系的组件数据传递
  • Vuex作用相当于一个用来存储共享变量的容器
    在这里插入图片描述
  • state用来存放共享变量的地方
  • getter,可以增加一个getter派生状态,(相当于store中的计算属性),用来获得共享变量的值
  • mutations用来存放修改state的方法。
  • actions也是用来存放修改state的方法,不过action是在mutations的基础上进行。常用来做一些异步操作
组件通过v-bind属性绑定向子组件共享数据。同时,子组件需要使用props接受数据。 父组件: <my-watch :msg="message" :user="userinfo"></my-watch> data() { return { message: '父传子v-bind,子接受props', userinfo:{name:'父v-bind',age:'子props'} tips:这里需要注意的是props是只读的,通过props接收的数据不可以在子组件直接修改值,子组件接收到的值只是一个引用,不过可以修改成功,只是会报错,我们有需求在子组件修改值的话,可以先转存一下再进行修改 现在我们有这样一个App.vue组件,它的子组件为Son.vue 我们想要让子组件来使用App.vue组件数据: 1.我们想要关联这俩个
导读: 本篇文章会讲到Vue重要的一个问题,就是组件组件之间怎么进行数据共享?之前我们有说过,每个组件之间是相互独立的,可以通过导入组件以及注册组件的方式进行使用,那我们组件之间怎么传递数据呢? 1、组件之间的关系 在开发 经常见到的关系分为以下几种: 父子组件(父子关系) 兄弟组件(兄弟关系) 可以看下关系图 A——B A——C 父子关系 B-C 兄弟关系 #mermaid-svg-H9vkRwclTBeIS6nt .label{font-family:'trebuchet ms',.
组件实例的作用域是孤立的。也就是说,子组件的是无法直接获取到父组件数据的。VueJS 为组件开发提供了 props,通过 props ,父组件数据将能够传递给子组件,而子组件则需要提前对 props 进行声明以便接收父组件传递过来的数据。 在对通用组件进行封装时,合理地使用 props 能够提升组件的复用性。 我们可以在使用组件时,通过使用在子组件使用 props 定义的属性来向子组件传递数据。 驼峰式命名 HTML 是 不区分大小写的。如果在一个 HTML 元素存在多个同名属