NO--16 vue之父子组件传值
先创建项目并运行
vue init webpack-simple template
cd template
npm i
npm run dev
一、子组件访问父组件的数据
方式一 :子组件直接访问父组件的数据
- 父组件在调用子组件时,绑定想要获取的父组件中的数据
- 在子组件内部,使用 props 选项声明获取的数据,即接收来自父组件中的数据
创建如下目录

App.vue 中写入
<template>
<div class="hello">
<h3>我是 App 父组件</h3>
<h4>访问自己的数据:{{msg}},{{name}},{{user.id}}</h4>
<hr>
<!-- 1. 在调用子组件时,绑定想要获取的父组件中的数据 -->
<Hello :message="msg" :name="name" :user="user"></Hello>
</div>
</template>
<script>
// 引入 Hello 组件
import Hello from './assets/components/Hello.vue'
export default {
data(){
return {
msg:'父组件',
name:'tom',
age:'22',
user:{
id:1234,
userName:'Jack'
}
}
},
// 注册 Hello 组件
components:{
Hello
}
}
</script>
Hello.vue 文件中写入
<template>
<div class="hello">
<h3>我是 hello 子组件</h3>
<!-- 在页面中直接渲染即可 -->
<h4>访问父组件中的数据: {{message}},{{name}},{{user.id}}</h4>
</div>
</template>
<script>
export default {
// 2. 在子组件内部,使用 props 选项声明获取的数据,即接收来自父组件中的数据
props:['message','name','user']
}
</script>
最后效果:

方式二 :为组件的 prop 指定 验证 规则,如果传入的数据不符合要求,Vue 会发出警告
- 父组件在调用子组件时,绑定想要获取的父组件中的数据
- 在 props 内以对象的形式写入校验规则
App.vue 中写入
<template>
<div class="hello">
<h3>我是 App 父组件</h3>
<h4>访问自己的数据:{{msg}},{{name}},{{user.id}}</h4>
<hr>
<!-- 1. 在调用子组件时,绑定想要获取的父组件中的数据 -->
<Hello :message="msg" :name="name" :age="age" :user="user" :money="money"></Hello>
</div>
</template>
<script>
// 引入 Hello 组件
import Hello from './assets/components/Hello.vue'
export default {
data(){
return {
msg:'父组件',
name:'tom',
age:'22',
user:{
id:9876,
userName:'Jack'
},
money:'123'
}
},
// 注册 Hello 组件
components:{
Hello
}
}
</script>
Hello.vue 中写入
<template>
<div class="hello">
<h3>我是 hello 子组件</h3>
<!-- 在页面中直接渲染即可 -->
<h4>访问父组件中的数据:
{{message}} <br>
{{name}}<br>
{{user.id}}<br>
{{user.userName}}<br>
{{age}}<br>
{{ageOne}}<br>
{{money}}<br>
</h4>
</div>
</template>
<script>
export default {
props:{
// 基础类型检测 (`null` 指允许任何类型)
message:String,
// 可能是多种类型
name:[String,Number],
// 必传且是字符串
age:{
type:String,
required:true
},
// 数值且有默认值 如果父组件中没有该数据绑定,显示以下的默认值
ageOne:{
type: Number,
default: 10
},
// 数组/对象的默认值应当由一个工厂函数返回
user:{
type:Object,
default:function(){
return {
userName: 'Doctor'
}
}
},
// 自定义验证函数
money:{
validator:function(value){
return value > 100
}
}
}
}
</script>
效果如下

注意:Prop 是单向绑定的:当父组件的属性变化时,将传导给子组件,但是反过来不会。这是为了防止子组件无意间修改了父组件的状态,来避免应用的数据流变得难以理解。
另外,每次父组件更新时,子组件的所有 prop 都会更新为最新值。这意味着你不应该在子组件内部改变 prop。
二、父组件访问子组件的数据
- 在子组件中使用 $emit(事件名,数据) 触发一个自定义事件发送数据
- 在父组件在使用子组件的标签内监听子组件的触发事件,并在父组件中定义方法用来获取数据
在 Hello.vue 中写入
<template>
<div class="hello">
<h3>我是 hello 子组件</h3>
<h4>访问自己的数据:
{{msg}} <br>
{{name}}
</h4>
<!-- 触发 send 事件 ,发送数据 -->
<button @click="send">将子组件中的数据发送给父组件</button>
</div>
</template>
<script>
export default {
data(){
return {
msg:'子组件',
name:'tom'
}
},
methods:{
// 在此处定义事件,用来发送数据,也可直接写到 mounted 内自动发送
send(){
// 此处的 this 表示当前子组件的实例
this.$emit('hello',this.msg,this.name)
}
}
}
</script>
在 App.vue 中写入
<template>
<div class="hello">
<h3>我是 App 父组件</h3>
<!-- 6. 在页面中渲染 -->
<h4>访问子组件的数据:{{msg}},{{name}}</h4>
<hr>
<!-- 子组件 -->
<!-- 3. 在子组件标签内监听子组件事件的触发 -->
<Hello @hello="getData"></Hello>
</div>
</template>
<script>
// 引入 Hello 组件
import Hello from './assets/components/Hello.vue'
export default {
data(){
return {
// 4. 初始化数据对象
msg:'',
name:'',
}
},
methods:{
// 5. 接收子组件传过来的数据
getData(msg,name){
this.msg = msg,
this.name = name
}
},
// 注册 Hello 组件
components:{
Hello
}
}
</script>
效果图:

NO--16 vue之父子组件传值的更多相关文章
- vue 非父子组件传值
/*非父子组件传值 1.新建一个js文件 然后引入vue 实例化vue 最后暴露这个实例 2.在要广播的地方引入刚才定义的实例 3.通过 VueEmit.$emit('名称','数据') 4.在接收收 ...
- Vue中非父子组件传值的问题
父子组件传值的问题,前面已经讲过,不再叙述,这里来说一种非父子组件的传值. vue官网指出,可以使用一个空vue实例作为事件中央线! 也就是说 非父子组件之间的通信,必须要有公共的实例(可以是空的), ...
- Vue非父子组件传值
<template> <div id="app"> <v-home></v-home> <br> <hr> ...
- vue 中父子组件传值:props和$emit
更新----------- 1 父组件向子组件传值:通过props数组: 在vue-cli Login.vue父组件中有AcceptAndRefuse.vue子组件,首先import进子组件hello ...
- vue中父子组件传值问题 通过props 和 $emit()方法
(代码在最后) 1.父组件给子组件传值直接通过props,听着很简单,但是对于初学者来说还是比较难以理解的,今天小白通过自己的实践操作结合代码分析一下 案例 把模态框单独的抽离出来,当作一个组件 第 ...
- vue ref父子组件传值
一. ref使用在父组件上 父组件html: <information ref='information'></information> import information ...
- Vue组件传值(二)之 非父子组件传值
Vue中非父子组件之间是如何实现通信的? 本章主要讲的是非父子组件传值,父子组件传值请看上一篇文章. 1.创建新的Vue实例引入项目中,通过$emit.$on来实现非父子组件传值: 1 <!DO ...
- 【vue】父组件主动调用子组件 /// 非父子组件传值
一 父组件主动调用子组件: 注意:在父组件使用子组件的标签上注入ref属性,例如: <div id="home"> <v-header ref="he ...
- vue父子组件传值加例子
例子:http://element-cn.eleme.io/#/zh-CN/component/form 上进行改的 父传子:用prop:子组件能够改变父组件的值,是共享的,和父操作是 ...
随机推荐
- SpringMVC如何防御CSRF
本文说一下SpringMVC如何防御CSRF(Cross-site request forgery跨站请求伪造)和XSS(Cross site script跨站脚本攻击). 说说CSRF 对CSRF来 ...
- virtualbox+vagrant学习-2(command cli)-23-vagrant version命令
Version 格式: vagrant version options只有 -h, --help 该命令将告诉你已安装的vagrant版本以及当前可用的vagrant最新版本. userdeMacBo ...
- 集合之HashSet
在前篇博文中(java提高篇(二三)-----HashMap)详细讲解了HashMap的实现过程,对于HashSet而言,它是基于HashMap来实现的,底层采用HashMap来保存元素.所以如果对H ...
- CS231N assignment1
# Visualize some examples from the dataset. # We show a few examples of training images from each cl ...
- 一个简单好用的http服务器
http-server 是一个简单的零配置命令行HTTP服务器, 基于 nodeJs. 如果你不想重复的写 nodeJs 的 web-server.js, 则可以使用这个. 安装 (全局安装加 -g) ...
- P1120 小木棍 [数据加强版]
题目描述 乔治有一些同样长的小木棍,他把这些木棍随意砍成几段,直到每段的长都不超过50. 现在,他想把小木棍拼接成原来的样子,但是却忘记了自己开始时有多少根木棍和它们的长度. 给出每段小木棍的长度,编 ...
- 【 腾讯敏捷转型No.4 】为什么敏捷团队不要超过15人
早期,腾讯公司的架构是比较简单的.从上至下分别是:公司——商业单元(BU)——部门——组——员工,每个部门基本上就是负责一个大的产品,每个组都是按照专业进行分工和管理,例如:产品组.终端组.后台组.设 ...
- OO——求导作业总结
目录 OO--求导作业总结 程序结构的分析 第一次作业 第二次作业 第三次作业 对多项式合法性判断的讨论 程序bug的分析 未通过的互测bug bug的位置与程序结构的关系 继承和接口的使用 互测 手 ...
- CentOS7.6离线安装MySql5.7
准备好mysql的离线安装文件: MySql官网下载mysql-5.7.25-1.el7.x86_64.rpm-bundle,并复制到/usr/mysql文件夹中. 删除CentOS自带的MariaD ...
- canvas 绘制双线技巧
楔子 最近一个项目,需要绘制双线的效果,双线效果表示的是轨道(类似铁轨之类的),如下图所示: 负责这块功能开发的小伙,姑且称之为L吧,最开始是通过数学计算的方式来实现这种双线,也就是在原来的路径的基础 ...