vue父子组件的通信
一、父组件向子组件传递数据
1、首先形成父子组件关系
<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<title>Document</title>
<script src="../js/vue.js"></script>
</head> <body>
<div id="app"> </div> <template id="cpn">
<div>
<h2>{{cmovies}}</h2>
<p>{{cmessage}}</p>
</div>
</template>
<script>
const cpn = {
template: `#cpn`,
data() {
return {}
},
methods: {}
}
let vm = new Vue({
el: '#app',
data: () => ({
message: '父组件的数据',
movies: ['战狼1', '流浪地球', '攀登者']
}),
components: {
cpn
}
})
</script>
</body> </html>
2、在子组件中定义一个props,定义两个变量 (messages) (moviess)
props: ['messages', 'moviess']
3、使用子组件时,用V-bind绑定两个变量(messages) (moviess),并且把父组件中的数据(message)(movies)传给这两个变量。
<cpn :messages="message" :moviess="movies"></cpn>
<!-- 不支持驼峰命名法 大写字母之间用 - 隔开 -->
****完整代码*****
<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<title>Document</title>
<script src="../js/vue.js"></script>
</head> <body>
<div id="app">
<cpn :messages="message" :moviess="movies"></cpn>
<!-- 不支持驼峰命名法 大写字母之间用 - 隔开 -->
</div>
<!-- 父传子 -->
<!--
1、建立父子关系
2、在子组件中定义一个props,定义两个变量 (messages) (moviess)
3、使用子组件时,用V-bind绑定两个变量,并且把父组件中的数据(message)(movies)传给这两个变量。 -->
<template id="cpn">
<div>
<h2>{{messages}}</h2>
<ul>
<li v-for="item in moviess">
{{item}}
</li>
</ul>
</div>
</template>
<script>
const cpn = {
template: `#cpn`,
// props: ['messages', 'moviess'], props: {
// 1、类型限制
// messages:Array,
// moviess:String, // 提供一些默认值
messages: {
type: String,
default: 'aaaa',
required: true
},
// 当使用组件的时候,没有绑定props中定义的变量,就会显示定义的默认值
moviess: {
// 类型是对象或数组,默认值必需是一个函数。
type: Array,
// default: []
default() {
return []
}
}
},
data() {
return {}
},
methods: {} }
let vm = new Vue({
el: '#app',
data: () => ({
message: '父组件的数据',
movies: ['战狼1', '流浪地球', '攀登者'], }),
components: {
cpn
}
})
</script>
</body> </html>
** props中补充写法
props: {
// 1、类型限制
// messages:Array,
// moviess:String, // 提供一些默认值
messages: {
type: String,
default: 'aaaa',
required: true
},
// 当使用组件的时候,没有绑定props中定义的变量,就会显示定义的默认值
moviess: {
// 类型是对象或数组,默认值必需是一个函数。
type: Array,
// default: []
default() {
return []
}
}
}
二、子组件向父组件传数据
1、构成父子组件关系
2、在子组件中自定义一个事件 作用:发射一个事件给父组件
<button v-for="item in categories" @click="btnclick(item)">{{item.name}}</button>
methods: {
btnclick: function (item) {
// 发射事件:自定义事件
this.$emit('itemclick', item)
}
}
3、在父组件的模板中使用子组件中定义的事件 @itemclick="cpnclick" 并且在父组件创建一个新的事件 cpnclick
<cpn @itemclick="cpnclick"></cpn>
methods: {
cpnclick: function (item) {
console.log('cpnclick', item)
}
}
***完整代码***
<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<script src="../js/vue.js"></script>
</head>
<!-- 父组件模板 -->
<div id="app">
<cpn @itemclick="cpnclick"></cpn>
</div>
<!--
1、构成父子组件关系
2、在子组件定义一个事件,作用是 发射一个事件给父组件。this.$emit('itemclick')
3、在父组件的模板中使用子组件中定义的事件 @itemclick="cpnclick" ,并且在父组件创建一个新的事件 cpnclick ,
这里面可以写传给父组件数据的逻辑以及限制
--> <body>
<!-- 子组件模板 -->
<template id="cpn">
<div>
<button v-for="item in categories" @click="btnclick(item)">{{item.name}}</button>
</div>
</template>
<script>
// 子组件
const cpn = {
template: `#cpn`,
data() {
return {
categories: [
{ id: 'aa', name: '热门推荐' },
{ id: 'bb', name: '手机数码' },
{ id: 'cc', name: '智能家居' },
{ id: 'dd', name: '美容美发' }
]
}
},
methods: {
btnclick: function (item) {
// 发射事件:自定义事件
this.$emit('itemclick', item)
}
}
}
// 父组件
let vm = new Vue({
el: '#app',
data: () => ({}),
components: {
cpn
},
methods: {
cpnclick: function (item) {
console.log('cpnclick', item)
}
}
})
</script>
</body> </html>
vue父子组件的通信的更多相关文章
- vue:父子组件间通信,父组件调用子组件方法进行校验子组件的表单
参考: ElementUI多个子组件表单的校验管理:https://www.jianshu.com/p/541d8b18cf95 Vue 子组件调用父组件方法总结:https://juejin.im/ ...
- VUE 父子组件之间通信传值 props和 $emit
1.父组件传值给子组件 $props,子组件传值给父组件 $emit 父组件 <div id="app" > <tr ...
- [前端开发]Vue父子组件的通信及访问
父传子 props 子传父 自定义事件emit props传数组 props:['cmovies','cmessage'] props传对象 props:{ //1.类型限制 cmovies:Arra ...
- Vue父子组件之间通信
1.父 -> 子.通过props //father.vue <template> <div id="father"> <div><l ...
- vue 父子组件通信详解
这是一篇详细讲解vue父子组件之间通信的文章,初始学习vue的时候,总是搞不清楚几个情况 通过props在父子组件传值时,v-bind:data="data",props接收的到底 ...
- vue父子组件通信
一.父子组件间通信 vue.js 2.0提供了一个ref 的属性: 可以为子组件指定一个索引id 父组件: <template> <div id='user-login'> & ...
- Vue的父子组件间通信及借助$emit和$on解除父子级通信的耦合度高的问题
1.父子级间通信,父类找子类非常容易,直接在子组件上加一个ref,父组件直接通过this.$refs操作子组件的数据和方法 父 这边子组件中 就完成了父 => 子组件通信 2. 子 =&g ...
- 【转】vue父子组件之间的通信
vue父子组件之间的通信 在vue组件通信中其中最常见通信方式就是父子组件之中的通性,而父子组件的设定方式在不同情况下又各有不同.最常见的就是父组件为控制组件子组件为视图组件.父组件传递数据给子组件使 ...
- 【Vue课堂】Vue.js 父子组件之间通信的十种方式
这篇文章介绍了Vue.js 父子组件之间通信的十种方式,不管是初学者还是已经在用 Vue 的开发者都会有所收获.无可否认,现在无论大厂还是小厂都已经用上了 Vue.js 框架,简单易上手不说,教程详尽 ...
随机推荐
- 本地Yum源配置
一.网络源 yum list 软件名称 查找源里的软件,可以使用通配符 二.配置源 源配置文件路径 /etc/yum.repos.d/ 配置项 [名称] 源标识(不能和其他的源重复) name=名称 ...
- [b0033] python 归纳 (十八)_队列Queue在多线程中使用(二)
# -*- coding: UTF-8 -*- """ 多线程同时读队列 使用 join(), task_done() 逻辑: 3个子线程并发 从有6个数据的队列中取数据 ...
- [b0028] python 归纳 (十三)_队列Queue在多线程中使用
# -*- coding: UTF-8 -*- """ 多线程同时读队列 总结: 1. 会阻塞 if self._jobq.qsize() > 0 进入逻辑,此时被 ...
- js 判断当前时间是否处于某个一个时间段内
js 判断当前时间(或者所选时间)是否在某一时间段 我们可以使用 jutils - JavaScript常用函数库的 isDuringDate 函数来实现 传入 beginDateStr (开始时间) ...
- Matplotlib 日期格式转换
官网链接:https://matplotlib.org/api/dates_api.html#matplotlib.dates.date2num import numpy as np import d ...
- PyQt5-TableWidget 表格视图
基于PyQt5 postgreSQL实现简单的数据插入.数据表格查询. 运行前需要安装psycopg2 模块,配置好postgerSQL. 先看效果图: 第1列为日期时间.第2列为自增1的编号.第3到 ...
- python使用open的OSError: [Errno 22] Invalid argument错误
这两天在写一个新闻类的spider时,遇到了OSError: [Errno 22] Invalid argument这个错误,苦恼的两天,无果.后来通过请教学长,发现原来是打开的文件名中含有一些系统的 ...
- [C7] 支持向量机(Support Vector Machines) (待整理)
支持向量机(Support Vector Machines) 优化目标(Optimization Objective) 到目前为止,你已经见过一系列不同的学习算法.在监督学习中,许多学习算法的性能都非 ...
- (day51)三、ORM、路由层、版本差异、流程图
目录 一.ORM关系建立 (一)ForeignKey(一对多) (二)ManyToManyField(多对多) (三)OneToOneField(一对一) 二.django请求生命周期流程图 三.ur ...
- 【2019.8.8 慈溪模拟赛 T2】query(query)(分治+分类讨论)
分治 首先,我们考虑分治处理此问题. 每次处理区间\([l,r]\)时,我们先处理完\([l,mid]\)和\([mid+1,r]\)两个区间的答案,然后我们再考虑计算左区间与右区间之间的答案. 处理 ...