浅谈vue学习之组件通信
vue用组件化简化了我们编写代码的复杂度,组件之间经常会出现数据传递的情况,那么组件之间是怎样通信的呢?
使用props传递数据
组件实例的作用域是孤立的。这意味着不能 (也不应该) 在子组件的模板内直接引用父组件的数据。父组件的数据需要通过 prop 才能下发到子组件中。
假设我们现有一个这样的父组件
var vm = new Vue({
el: "#app",
data: {
parentMessage: 'h'
},
components: {
Child
}
})
可以看到在该父组件中注册了一个子组件Child,还有一条data数据parentMessage
接下来我们怎样在子组件Child中拿到parentMessage呢?
在子组件中这样写
var Child = {
//声明当前组件内部能够接受一个message的属性,如果是驼峰式命名,在传参数的时候使用短横线连接的小写
props: ["message", "myMessage"],
template: '<span>{{message}} {{myMessage}}</span>'
}
在子组件中我们在props中写了一个自定义属性mymessage来接收从父组件中传来的数据,然后通过该自定义属性在父组件中传递
<div id="app">
<child message="hello" :my-message="parentMessage"></child>
<child message="hi"></child>
<input type="text" v-model="parentMessage">
</div>
上述代码中我们使用自定义的属性my-message接收到了父组件中定义的数据parentMessage,然后再将这个数据传递到子组件中去显示,效果如下,我们拿到了父组件中的parentMessage
props接收后对数据的修改
在这里我只记录一下用子组件的计算属性去修改从父组件中拿到的数据
<div id="app">
<child :size="parentSize"></child>
</div>
<script src="./vue.js"></script>
<script>
var Child = {
template: '<div>{{size}}</div>',
props: ['size'],
}
var vm = new Vue({
el: '#app',
data: {
parentSize: 'THREE'
},
components: {
Child
}
})
</script>
如上代码,子组件中利用前面讲到的方法拿到了父组件中传递的parentSize,假如子组件直接写一个方法去修改父组件的数据在vue的单向数据流中是不可能的,这里我们可以将parentSize放到一个计算属性中去操作,相当于另外创建了一个对象
所以我们在子组件Child中写一个computed计算属性,其中写一条属性normalSize,来将size全部转换为小写
computed: {
normalSize() {
return this.size.trim().toLowerCase();
}
}
在子组件的模板中添加上计算属性normalSize的显示
template: '<div>{{size}} {{normalSize}}</div>'
结果如下
遍历并显示父组件传来的数组
在父组件中的data声明了一个数组lis
var vm = new Vue({
el: "#app",
data: {
lis: ['a', 'b', 'c']
},
components: {
List
}
})
在子组件中得到并遍历
var List = {
template: '<div><div v-for="item in lists">{{item}}</div></div>',
props: ['lists']
}
然后在父组件模板中将子组件显示出来
<div id="app">
<list :lists="lis"></list>
</div>
这里要注意数据传递的过程
首先还是像之前一样通过自定义属性在父组件模板中得到数组,然后传递到子组件的模板中去使用
非父子组件之间的通信
要实现非父子组件之间的通信就不得不说到$emit
发出的可以被自定义监听的事件,这里我通过一个小示例来解释一下
子组件事件实现父组件数据的变化
这里是一个点击子组件让父组件中count统计点击次数的示例
<div id="app">
{{total}}
<!--在child组件中添加一个监听事件来监听自定义事件add-parent-total,当触发本事件时执行父组件中的addTotal方法使得total改变-->
<child @add-parent-total="addTotal"></child>
<child></child>
</div>
<script src="vue.js" charset="utf-8"></script>
<script>
var Child = {
template: '<button @click="add">{{counter}}</button>',//子组件模板的button中添加一个点击事件,来调用子组件中的方法,add
data() {
return {
counter: 0
}
},
methods: {
//在子组件中写一个方法来通过$emit触发一个自定义的add-parent-total事件
add() {
this.counter++;
this.$emit('add-parent-total');
}
}
}
var vm = new Vue({
el: '#app',
data: {
total: 0
},
methods: {
addTotal(preload) {//在父组件添加一个方法,来操作父组件中的数据total
this.total += 1;
}
},
components: {
Child
}
})
</script>
在上面的例子中我们还是无法绕过子组件无法改变父组件中内容的事实,但是我们通过触发父组件模板中的一个自定义事件,让父组件自己调用自己的方法,改变了自己的内容,利用了自定义事件和$emit的方式
非父子组件通信
在非父子组件通信的时候我们通过一个空的vue对象来实现
首先声明一个vue实例
var vm = new Vue({
el: '#app',
data: {
},
components: {
AppHead,
AppBody
}
})
在实例中注册了两个组件,他们两个算是兄弟组件,我们就让这两个兄弟组件实现通信
接着声明一个空的vue实例
var bus = new Vue()
然后去写两个子组件
var AppHead = {
template: '<div><button @click="add">添加</button></div>',
methods: {
add() {
bus.$emit('change', 1)
}
}
}
var AppBody = {
template: `<div>{{counter}}</div>`,
data() {
return {
counter: 0
}
},
created() {
bus.$on('change', count => {
this.counter += count
})
}
}
在AppHead组件中我们让它在被点击是触发一个add方法,这个add 方法用来发出一个基于bus发出的自定义事件change
然后在AppBody中写了一个在AppBody被创建之后就会时刻监听bus 的change事件的方法,这样一旦change事件被触发就会执行这个监听事件,实现了兄弟组件之间的通信
添加上父组件的模板将两个兄弟组件放进去实现效果
<div id="app">
<app-head></app-head>
<app-body></app-body>
</div>
浅谈vue学习之组件通信的更多相关文章
- Vue学习笔记-组件通信-子传父(自定义事件)
props用于父组件向子组件传递数据,还有一种比较常见的是子组件传递数据或事件到父组件中.我们应该如何处理呢?这个时候,我们需要使用自定义事件来完成.什么时候需要自定义事件呢?当子组件需要向父组件传递 ...
- Vue学习笔记-组件通信-父传子(props中的驼峰标识)
在组件中,使用选项props来声明需要从父级接收到的数据.props的值有两种方式:方式一:字符串数组,数组中的字符串就是传递时的名称.方式二:对象,对象可以设置传递时的类型,也可以设置默认值等. & ...
- 浅谈Vue不同场景下组件间的数据交流
浅谈Vue不同场景下组件间的数据“交流” Vue的官方文档可以说是很详细了.在我看来,它和react等其他框架文档一样,讲述的方式的更多的是“方法论”,而不是“场景论”,这也就导致了:我们在阅读完 ...
- 【Vue】浅谈Vue不同场景下组件间的数据交流
浅谈Vue不同场景下组件间的数据“交流” Vue的官方文档可以说是很详细了.在我看来,它和react等其他框架文档一样,讲述的方式的更多的是“方法论”,而不是“场景论”,这也就导致了:我们在阅读完 ...
- 浅谈Vue.js
作为一名Vue.js的忠实用户,我想有必要写点文章来歌颂这一门美好的语言了,我给它的总体评价是“简单却不失优雅,小巧而不乏大匠”,下面将围绕这句话给大家介绍Vue.js,希望能够激发你对Vue.js的 ...
- 浅谈Vue响应式(数组变异方法)
很多初使用Vue的同学会发现,在改变数组的值的时候,值确实是改变了,但是视图却无动于衷,果然是因为数组太高冷了吗? 查看官方文档才发现,不是女神太高冷,而是你没用对方法. 看来想让女神自己动,关键得用 ...
- 浅谈Vue下的components模板
浅谈Vue下的components模板在我们越来越深入Vue时,我们会发现我们对HTML代码的工程量会越来越少,今天我们来谈谈Vue下的 components模板的 初步使用方法与 应用 我们先来简单 ...
- Vue 非父子组件通信方案
Vue 非父子组件通信方案 概述 在 Vue 中模块间的通信很普遍 如果是单纯的父子组件间传递信息,父组件可以使用 props 将数据向下传递到子组件,而在子组件中可以使用 events (父组件需要 ...
- 转:浅谈深度学习(Deep Learning)的基本思想和方法
浅谈深度学习(Deep Learning)的基本思想和方法 参考:http://blog.csdn.net/xianlingmao/article/details/8478562 深度学习(Deep ...
随机推荐
- vue项目中利用popstate处理页面返回操作
需求背景:项目中需要做一个返回确认,避免用户误触返回键而退出当前页面. 原理:利用history和浏览器刷新popstate状态 实现: 1.在mounted() 阶段判断并添加popstate事件监 ...
- 签发的用户认证token超时刷新策略
https://segmentfault.com/a/1190000014545422
- java打分系统
package com.ioTest; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.Fil ...
- Delphi---ShellExecute跨进程调用exe
测试环境:Delphi7 + Win7 发起端 unit uRequest; interface uses Windows, Messages, SysUtils, Variants, Classes ...
- Python的题目
1.将元组 (1,2,3) 和集合 {4,5,6} 合并成一个列表.2.在列表 [1,2,3,4,5,6] 首尾分别添加整型元素 7 和 0.3.反转列表 [0,1,2,3,4,5,6,7] .4.反 ...
- 【NOIP2016提高A组集训第3场10.31】高维宇宙
题解 分析 因为只有奇数和偶数配对才有可能得出质数, 暴力求出每一对\(a_i+a_j\)为质数,将其中的奇数想偶数连一条边. 二分图匹配,匈牙利算法. #include <cmath> ...
- lazarus 线程调试
lazarus站点的文档中看到的.简单用法: uses LCLProc; DbgOutThreadLog (msg: string); overload; --有好几个不同参数的定义.
- C# WPF开机自启动和只允许一个程序运行
本文出自:https://www.cnblogs.com/2186009311CFF/p/10024949.html 在App.xaml.cs填充一下内容,即可实现只允许一个运行,且不解锁屏幕的情况下 ...
- JPA学习(六、JPA_JPQL)
框架学习之JPA(六) JPA是Java Persistence API的简称,中文名Java持久层API,是JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中 ...
- 数据:ContentResolver类
ContentResolver是通过URI来查询ContentProvider中提供的数据.除了URI以 外,还必须知道需要获取的数据段的名称,以及此数据段的数据类型. 如果你需要获取一个特定的记 ...