Vue 的单文件组件在使用 Vue 时非常常用,所以我们也会经常遇到组件之间需要传递数据的时候,大致分为三种情况:

文档中也已经详细的说明了各种情况下的解决方法,但是现在我在还没有阅读多少文档的情况下,没有找到有单文件组件方面的具体书写方式,智商和理解能力有限的情况下,自己尝试了一下,最后发现其实是一样的。所以这篇文章其实是废话,但是还是想记录一下,不枉自己花了一个多小时。
准备工作,我新建了 6 个文件,分别是:
父组件向子组件传递数据,通过 props 传递数据。
这里我以 page 向 msg 传递数据为例:page.vue 中
<template>
<div class="page">
page
<msg :love="message"></msg>
</div>
</template>
<script>
import msg from './msg.vue'
export default {
name: 'page',
components: { msg },
data () {
return {
message: 'page-msg'
}
}
}
</script>
msg.vue 中
<template>
<div class="msg">
{{ love }}
</div>
</template>
<script>
export default {
name: 'msg',
props: ['love']
}
</script>
这样以后就会发现,实现了把父组件 page 中的数据传递到子组件 msg 中了。
另外,需要强调一下的是,不要在子组件中修改 props 的值,当然修改是有效的,非常不推荐,而且 Vue 也会有警告提示。正确的做法是传递给 data 中的属性或者计算属性。props 中的值是可以通过 this.love 访问到的。
特别注意 props 值是引用类型时的情况,不可以进行简单的赋值,会影响到父组件,正确的做法是进行深拷贝。
子组件向父组件传递数据,通过 events 传递数据。
父组件 page.vue 中
<template>
<div class="page">
page
<msg @passData="getData"></msg>
</div>
</template>
<script>
import msg from './msg.vue'
export default {
name: 'page',
components: { msg },
data () {
return {
message: 'hi'
}
},
methods: {
getData (data) {
console.log(data)
}
}
}
</script>
子组件 msg.vue 中
<template>
<div class="msg">
{{ msg }}
<button @click="pass">点击</button>
</div>
</template>
<script>
export default {
name: 'msg',
data () {
return {
msg: 'hello'
}
},
methods: {
pass () {
this.$emit('passData', 'success')
}
}
}
</script>
点击后就会发现 console 出了 'success'。
同级元素之间传递数据,通过 event bus 来传递。
需要引入一个 Vue 实例 作为中央总线。page 组件中
<template>
<div class="page">
page
<button @click="changeMsg">click</button>
</div>
</template>
<script>
import msg from './msg.vue'
import { bus } from '../bus.js'
export default {
name: 'page',
components: { msg },
data () {
return {
message: 'hi'
}
},
methods: {
changeMsg () {
bus.$emit('change', '666')
}
}
}
</script>
footer 组件中
<template>
<div class="footer">
footer
</div>
</template>
<script>
import { bus } from '../bus.js'
export default {
name: 'footer',
data () {
return {
msg: 'hi'
}
},
created () {
bus.$on('change',(data)=>{
console.log(data)
})
}
}
</script>
嗯,最后发现打印出来了 '666',这样就实现了。
最后总结一下:
父组件向子组件传递数据,通过 props 传递数据。具体做法只需要在父组件中绑定,在子组件中声明。
//父组件
<father>
<child :love="msg"></child>
</father>
//子组件
export default {
...
props: ['love']
}
子组件向父组件传递数据,通过 events 传递数据。具体做法时在父组件中监听,在子组件中触发。
<father>
<child @passData="getData"></child>
</father>
//子组件
export default {
...
methods: {
pass () {
this.$emit('passData', 'hi')
}
}
}
两个同级组件之间传递数据,通过 event bus 传递数据。
import { bus } from './bus.js'//两个组件都要引入
//触发事件
export default {
...
methods: {
passData () {
this.$emit('communicate', 'hello')
}
}
}
//监听事件
export default {
...
mounted: {
this.$on('communicate', (data) => {
//...
})
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关文章:
如何选择香港主机高效搭建外贸独立站?
高防服务器租用首荐平台,企业级优惠套餐快速部署
交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?
南宁网站建设制作定制,南宁网站建设可以定制吗?
定制建站平台哪家好?企业官网搭建与快速建站方案推荐
建站主机解析:虚拟主机配置与服务器选择指南
如何在宝塔面板中创建新站点?
整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?
如何在阿里云完成域名注册与建站?
微课制作网站有哪些,微课网怎么进?
清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?
如何通过二级域名建站提升品牌影响力?
香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南
制作网站的软件免费下载,免费制作app哪个平台好?
如何快速配置高效服务器建站软件?
利用JavaScript实现拖拽改变元素大小
音响网站制作视频教程,隆霸音响官方网站?
网站代码制作软件有哪些,如何生成自己网站的代码?
安徽网站建设与外贸建站服务专业定制方案
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
建站三合一如何选?哪家性价比更高?
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
陕西网站制作公司有哪些,陕西凌云电器有限公司官网?
无锡营销型网站制作公司,无锡网选车牌流程?
建站VPS推荐:2025年高性能服务器配置指南
建站之星如何防范黑客攻击与数据泄露?
如何用PHP快速搭建高效网站?分步指南
制作网站公司那家好,网络公司是做什么的?
建站之星展会模版如何一键下载生成?
,网站推广常用方法?
如何将凡科建站内容保存为本地文件?
建站主机与服务器功能差异如何区分?
电商平台网站制作流程,电商网站如何制作?
如何构建满足综合性能需求的优质建站方案?
logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?
网站按钮制作软件,如何实现网页中按钮的自动点击?
如何在企业微信快速生成手机电脑官网?
在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?
企业网站制作公司网页,推荐几家专业的天津网站制作公司?
宝塔建站助手安装配置与建站模板使用全流程解析
如何在宝塔面板创建新站点?
IOS倒计时设置UIButton标题title的抖动问题
威客平台建站流程解析:高效搭建教程与设计优化方案
如何快速生成专业多端适配建站电话?
太原网站制作公司有哪些,网约车营运证查询官网?
建站与域名管理如何高效结合?
如何选购建站域名与空间?自助平台全解析
如何通过VPS建站无需域名直接访问?
淘宝制作网站有哪些,淘宝网官网主页?
*请认真填写需求信息,我们会在24小时内与您取得联系。