vue的组件通讯
Vue的组件通讯又称组件传值
一、父子组件传值:
父组件:
<子组件名 :动态变量名 (随便起)='你想要传递的数据' ></子组件名>
子组件:
利用 prop去接收父组件传过来的值
props:[ '父组件传递过来的动态变量(可以接收多个)' ]
** 注意点
props属性的优先级要高于data属性(data中的参数值不要和props中的值的名字重复,否则会覆盖)
父组件传值是单项数据且不能跨代传值
二、子父组件传值
子组件:
<button @click='事件名称' ></button>
methods:{
事件名称(){
//利用事件触发器以及自定义事件名称发送数据
this.$emit('自定义事件名称',数据)
}
}
父组件:
<子组件 @定义事件名称='事件名称(自己新定义的事件名,用来接收数据,触发事件)'> </子组件>
methods:{
事件名称(e){
// e 是数据源,就是子组件传递过来的数据
}
}
三、兄弟组件传值(非父子传值)
实现的方法有三种:
1 单一事件(缺点,必须在同一个页面,主要用于兄弟组件)
//在main.js中给Vue实例添加一个方法,接下来所有的组件都可以使用这个方法
Vue.prototype.eventBus(定义的变量) = new Vue()
//自定义的兄弟页面VB.vue页面
<div><button @click='toA'>传送数据给A</button></div>
methods:{
toA( ){
//发送数据给A
//调用触发事件
//$emit('事件名称', 数据)
this.eventBus.$emit('sendA', this.msg)
}
}
//自定义的兄弟页面VA.vue
mounted(){
//调用实时监听事件的变化
this.eventBus.$on('sendA', (e)=>{
console.log(e,'接收到b的数据');
this.dataB = e ;
})
}
2 本地存储方法:
本地存储:localStorage
会话存储:sessionStorage
<button @click = ' toLocal '>本地存储</button>
methods:{
toLocal(){
//localStorage.setItem('本地存储的key','需要存储的数据')
localStorage.setItem('info',this.info)
}
}
接收本地存储的参数
mounted:{
this.info = localStorage.getItem('info(本地存储中的key值)')
}
会话存储:sessionStorage(方法一样):
<button @click = ' toLocal '>本地存储</button>
methods:{
toLocal(){
//localStorage.setItem('本地存储的key','需要存储的数据')
localStorage.setItem('info',this.info)
}
}
接收本地存储的参数
mounted:{
this.info = localStorage.getItem('info(本地存储中的key值)')
}
3 Vuex状态管理
vue的组件通讯的更多相关文章
- seventBus(封装) 一个巧妙的解决vue同级组件通讯的思路
如果在你项目中需要多处用到同级组件通讯,而又不想去写繁琐的vuex,可以参考这个小思路.本人在写项目中琢磨出来的,感觉挺好用,分享一下. 1.在utils文件夹下添加BusEvent.js 注释已经很 ...
- vue的组件通讯 父传子 -- 子传父-- 兄弟组件的传值 vue的组件传值
首先文字简单撸一下 父子传子 -------首先在父组件上绑定一个属性,在子组件里用props接收,可以是数组或者是对象 子传父 ------在父组件升上自定义一个方法,在子组件里通过this ...
- vue同胞组件通讯解决方案(以下为一种另外可用vuex解决)
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- 深入理解Vue父子组件通讯的属性和事件
在html中使用元素,会有一些属性,如class,id,还可以绑定事件,自定义组件也是可以的.当在一个组件中,使用了其他自定义组件时,就会利用子组件的属性和事件来和父组件进行数据交流. 父子组件之间的 ...
- Vue父子组件通讯
我们知道,父组件不能修改子组件的数据[这种说法是不严谨的],严谨的说法是:子组件内部不能修改从父组件传递过来的值.原因是vue遵循的是数据单向流原则,父组件传递数据给子组件只能单向绑定,通过Props ...
- vue组件通讯之provide / inject
什么是 provide / inject [传送门] vue的组件通讯方式我们熟知的有 props $emit bus vuex ,另外就是 provide/inject provide/inject ...
- 【Vue】Vue中的父子组件通讯以及使用sync同步父子组件数据
前言: 之前写过一篇文章<在不同场景下Vue组件间的数据交流>,但现在来看,其中关于“父子组件通信”的介绍仍有诸多缺漏或者不当之处, 正好这几天学习了关于用sync修饰符做父子组件数据双向 ...
- Vue组件通讯
Vue最常用的组件通讯有三种:父->子组件通讯.子->父组件通讯,兄弟组件通讯.(template用的pug模板语法) 1.父->子组件通讯 父->子组件通讯,是通过props ...
- Vue组件通讯黑科技
Vue组件通讯 组件可谓是 Vue框架的最有特色之一, 可以将一大块拆分为小零件最后组装起来.这样的好处易于维护.扩展和复用等. 提到 Vue的组件, 相必大家对Vue组件之间的数据流并不陌生.最常规 ...
随机推荐
- DjangoORM操作之其他知识点
一.F与Q查询 F查询 F查询的应用场景主要是当你想要查询字段需要与数据库中的另外一个字段进行比较的时候,基于我们前面所学的知识点无法完成,那就需要用到F查询. F的导入 from django.db ...
- hdu2612 又是迷宫系列
题目链接:http://icpc.njust.edu.cn/Problem/Hdu/2612/ 题意:有两个人在地图上不同的位置,地图上由若干个餐厅,求两人能同时到达一个餐厅所用最少的总时间. 代码如 ...
- 北邮OJ 89. 统计时间间隔 java版
89. 统计时间间隔 时间限制 1000 ms 内存限制 65536 KB 题目描述 给出两个时间(24小时制),求第一个时间至少要经过多久才能到达第二个时间.给出的时间一定满足的形式,其中x和y分别 ...
- excel中存储的icount,赋值完之后
最近需要实现一个功能,为了确保每次函数运行的时候count是唯一的,所以想读取excel中存储的icount,赋值完之后对其进行+1操作,并存入excel文件,确保下次读取的count是新的,没有出现 ...
- 原 c++中map与unordered_map的区别
c++中map与unordered_map的区别 头文件 map: #include < map > unordered_map: #include < unordered_map ...
- matplotlib.pyplot库函数关于坐标轴显示的支持
matplotlib.pyplot库函数关于坐标轴显示的支持 https://blog.csdn.net/Stark_595/article/details/80787005?depth_1-utm_ ...
- 编译原理:DFA最小化,语法分析初步
1.将DFA最小化:教材P65 第9题 解析: 2.构造以下文法相应的最小的DFA S→ 0A|1B A→ 1S|1 B→0S|0 解析: S→ 0A|1B →S → 0(1S|1)|1(0S|0 ...
- nginx代理图片访问
nginx代理图片访问 首先配置nginx的代理物理路径 我的是在E盘下面的image 1 #图片的代理 2 server { 3 listen 80; 4 #配置访问的域名 5 server_nam ...
- 1~n的之间的k个数组成和为n的方案数(动态规划)
绯色的子弹 Description 众所周知,夏季奥林匹克运动会时隔56年第二次在东京举办,紧接着出来的<名侦探柯南 M24绯色的子弹>竟也是有奥运会的背景,最重要的是重归主线!!!(赤井 ...
- java对象clone
java克隆 为什么需要克隆 我们在很多时候需要使用一个对象去记录另外一个对象的当前状态,对象中可能会有很多属性,如果我们一个一个去设置,不仅不方便,而且效率很低,我们看一个初学者可能遇到的问题 cl ...