浅谈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 ...
随机推荐
- Java线程与Linux内核线程的映射关系(转)
Java线程与Linux内核线程的映射关系 Java线程与Linux内核线程的映射关系Linux从内核2.6开始使用NPTL (Native POSIX Thread Library)支持,但这时线程 ...
- Codeforces Round #568 (Div. 2) A.Ropewalkers
链接: https://codeforces.com/contest/1185/problem/A 题意: Polycarp decided to relax on his weekend and v ...
- 《Python3-标准库》讲解
一.string:文本常量和模板 函数:capwords()-------------------------------------------------- import string s = ...
- C++中的取地址符(&)
这个符号特别容易混淆, 因为在C++中, &有两种不同用法: 获得变量地址 引用传递 第一个例子, int main() { std::string s = "Hello" ...
- C++中的字符数组、字符指、字符串针(腾讯)
一.字符数组 1.定义时进行初始化的方式 (1)char c[12]={'I',' ','a','m',' ','h','a','p','p','y'};//最后两个元素自动补‘\0’(不是空格),其 ...
- mysql——非主键自增
今天遇到一个问题: 要创建一张表,其中我想将ip和date这两列作为一个复合主键,可以通过如下语句修改表结构: alter table tb_name add primary key (字段1,字段2 ...
- 【leetcode】Valid Triangle Number
题目: Given an array consists of non-negative integers, your task is to count the number of triplets c ...
- 17.树的子结构(python)
题目描述 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) class Solution: def HasSubtree(self, pRoot1, pRoo ...
- vue-router中$route 和 $router
1.1 $route 表示(当前路由信息对象) 表示当前激活的路由的状态信息,包含了当前 URL 解析得到的信息,还有 URL 匹配到的 route records(路由记录).路由信息对象:即$ro ...
- docker-compose安装xxl-job
docker能安装的docker-compose肯定就能安装,锻炼一下写yml的能力. 后面再具体写实际中的应用 [root@localhost mysql]# cat docker-compose. ...