标签:实例 应用 问题 size bsp 依赖注入 title 触发事件 nat
(1)父组件向子组件传值props
<button-counter :title="send"></button-counter> Vue.component(‘button-counter‘, { props: [‘title‘], data: function() { return { count: 0 } },
(2)子组件向父组件传值 $emit(‘enlarge-text‘,10) on
子组件通过自定义事件向父组件传递数据 <button v-on:click="$emit(‘enlarge-text‘,10)"></button> 父组件监听子组件的事件 <menu-item v-on:enlarge-text="fontSize($event)"></menu-item>
( 3 ) 子组件之间相互传值 $emit(‘enlarge-text‘,10) on
<div id="riven"> <button-counter></button-counter> <button-counter2></button-counter2> <button @click="handel">清除事件</button> </div>
子组件一 methods: { handel: function() { //触发兄弟组件事件 hub.$emit("riven-event", 10) } }, mounted: function() { // 监听事件 hub.$on("mark-event", (val) => { this.count += val }) } 子组件二 methods: { handel: function() { //触发兄弟组件事件 hub.$emit("mark-event", 1) } }, mounted: function() { // 监听事件 hub.$on("riven-event", (val) => { this.count += val }) }
父组件 methods: { handel: function() { hub.$off("riven-event"); hub.$off("mark-event"); } }
(3)Vuex
适用于 父子、隔代、兄弟组件通信
Vue 组件间通信只要指以下 3 类通信:父子组件通信、隔代组件通信、兄弟组件通信,下面我们分别介绍每种通信方式且会说明此种方法可适用于哪类组件间通信。
(1)props / $emit
适用 父子组件通信
(2)ref
与 $parent / $children
适用 父子组件通信
ref
:如果在普通的 DOM 元素上使用,引用指向的就是 DOM 元素;如果用在子组件上,引用就指向组件实例$parent / $children
:访问父 / 子实例(3)EventBus ($emit / $on)
适用于 父子、隔代、兄弟组件通信
(4)$attrs/$listeners
适用于 隔代组件通信
$attrs
:包含了父作用域中不被 prop 所识别 (且获取) 的特性绑定 ( class 和 style 除外 )。当一个组件没有声明任何 prop 时,这里会包含所有父作用域的绑定 ( class 和 style 除外 ),并且可以通过 v-bind="$attrs"
传入内部组件。通常配合 inheritAttrs 选项一起使用。$listeners
:包含了父作用域中的 (不含 .native 修饰器的) v-on 事件监听器。它可以通过 v-on="$listeners"
传入内部组件(5)provide / inject
适用于 隔代组件通信
provide / inject API
主要解决了跨级组件间的通信问题,不过它的使用场景,主要是子组件获取上级组件的状态,跨级组件间建立了一种主动提供与依赖注入的关系。(6)Vuex
适用于 父子、隔代、兄弟组件通信
标签:实例 应用 问题 size bsp 依赖注入 title 触发事件 nat
原文地址:https://www.cnblogs.com/Rivend/p/12628764.html