Vue组件的11种通信方式总结

目录

1. provide / inject

2. props(父传子) 

3. $emit(子传父)

4. eventBus(全局创建Vue实例)

5. vuex(状态管理) 

6. $parent / $children / $refs (获取组件实例)

7. $attrs

8. $listeners

9. Vue.observable

10. mixin

11. 路由传值 /引用数据类型值传递实现父子间数据的共享 


组件是 vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用。
vue组件间的传值方式多种多样,并不局限于父子传值、事件传值这些。

1. provide / inject

这一组选项需要一起使用,允许一个祖先组件向其所有的后代组件注入一个依赖,不论组件层级有多深,并在其上下游关系成立的时间里始终生效.

// provide 选项应该是一个对象或返回一个对象的函数
// inject 选项应该是:一个字符串数组,或一个对象,对象的 key 是本地的绑定名

// 父级组件提供 'foo'
var Provider = {
  provide: {
    foo: 'bar'
  },
  // ...
}

// 子组件注入 'foo' (数组形式)
var Child = {
  inject: ['foo'],
  created () {
    console.log(this.foo) // => "bar"
  }
  // ...
}

或 (对象形式)
var Child = {
  inject: {
    foo: {
        from: 'bar', // 可选
        default: 'self defined content' // 默认值
    }
  },
  created () {
    console.log(this.foo) // => "bar"
  }
  // ...
}

需要注意的是: Vue 2.2.1 或更高版本中,inject注入的值会在props和data初始化之前得到

// 使用一个注入的值作为数据(data)的入口 或者 属性(props)的默认值
const Child = {
  inject: ['foo'],
  data () {
    return {
      bar: this.foo // 输出bar的值与foo相同
    }
  }
}

const Child = {
  inject: ['foo'],
  props: {
    bar: {
      default () {
        return this.foo
      }
    }
  }
}

-----------------------------------------------------------------------------------
// 注入可以通过设置默认值使其变成可选项
const Child = {
  inject: {
    foo: { // 注意: 此处key值必须是父组件中provide的属性的key
      from: 'bar', // 属性是在可用的注入内容中搜索用的 key (字符串或 Symbol), data或者props中的可搜索值
      default: 'foo' // 属性是降级情况下使用的 value, 默认值为 ‘foo’
    }
  }
}

// 与 prop 的默认值类似
const Child = {
  inject: {
    foo: {
      from: 'bar',
      default: () => [1, 2, 3] // 默认值为引用类型时,需要使用一个工厂方法返回对象
    }
  }
}

2. props(父传子) 

// 创建组件
Vue.component('props-demo-advanced', {
  props: {
    age: {
      type: Number,
      default: 0
    }
  }
})

// 父组件中注册和使用组件,并传值
<props-demo-advanced :age="age"> </props-demo-advanced>

3. $emit(子传父)

// 子组件Child, 负载payload可选
this.$emit('eventName', payload)

// 父组件 Parent
<Parent @evnetName="sayHi"></Parent>

4. eventBus(全局创建Vue实例)

                进行事件监听和数据传递。同时Vuex也是基于这个原理实现的 

// 三步使用
// 1. 创建
window.$bus = new Vue()

// 2. 注册事件
window.$bus.$on('user_task_change', (payload) => {
  console.log('事件触发')
})

// 3. 触发
window.$bus.$emit('user_task_change', payload)

5. vuex(状态管理) 

 目录结构如下

      其中vuex相关的三个文件counter.js、 index.js、 operate.js,内容如下:

 index.js

import Vue from 'vue'
import Vuex from 'vuex'
import counter from './counter.js'
import operate from './operate.js'
Vue.use(Vuex)

const state = {
  name: 'zhaoyh'
}

const getters = {
  getName (state) {
    return state.name
  }
}

const mutations = {
  changeName (state, payload) {
    state.name = `${state.name} ${payload}`
  }
}

const actions = {
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值