Vue 组件通信(二)

简介: Vue 组件通信

5、$parent 或$ root


通过共同祖辈p a r e n t 或者 parent或者parent或者root搭建通信侨联


兄弟组件

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


另一个兄弟组件

this.$parent.emit('add')


6、$attrs 与$ listeners


适用场景:祖先传递数据给子孙

image.png


// 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>


7、provide 与 inject


在祖先组件定义provide属性,返回传递的值

在后代组件通过inject接收组件传递过来的值


祖先组件

provide(){  
    return {  
        foo:'foo'  
    }  
}  


后代组件

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


8、vuex


适用场景: 复杂关系的组件数据传递


Vuex作用相当于一个用来存储共享变量的容器


9ab89587b31f8a886f781fbcd9c3ba64_65a889c4b0acce1605483d85f79e8bfc.png


state用来存放共享变量的地方


getter,可以增加一个getter派生状态,(相当于store中的计算属性),用来获得共享变量的值


mutations用来存放修改state的方法。


actions也是用来存放修改state的方法,不过action是在mutations的基础上进行。常用来做一些异步操作


小结


  • 父子关系的组件数据传递选择 props 与 $emit进行传递,也可选择ref
  • 兄弟关系的组件数据传递可选择$bus,其次可以选择$parent进行传递
  • 祖先与后代组件数据传递可选择attrs与listeners或者 Provide与 Inject
  • 复杂关系的组件数据传递可以通过vuex存放共享的变量


目录
相关文章
|
2天前
|
JavaScript
vue中watch的用法
vue中watch的用法
|
2天前
|
JavaScript 前端开发
vue动态添加style样式
vue动态添加style样式
|
1天前
|
存储 API
vue3中如何动态自定义创建组件并挂载
vue3中如何动态自定义创建组件并挂载
|
2天前
|
JavaScript 前端开发
Vue项目使用px2rem
Vue项目使用px2rem
|
1天前
|
JavaScript API
vue学习(13)监视属性
vue学习(13)监视属性
10 2
|
1天前
|
JavaScript
vue 函数化组件
vue 函数化组件
|
1天前
|
JavaScript
vue知识点
vue知识点
7 2
|
1天前
|
JavaScript 前端开发
vue学习(15)watch和computed
vue学习(15)watch和computed
9 1
|
1天前
|
JavaScript
vue学习(14)深度监视
vue学习(14)深度监视
10 0
|
6天前
|
JavaScript
Vue组件传值异步问题--子组件拿到数据较慢
Vue组件传值异步问题--子组件拿到数据较慢
11 0