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) => {
//...
})
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关文章:
定制建站策划方案_专业建站与网站建设方案一站式指南
微信网站制作公司有哪些,民生银行办理公司开户怎么在微信网页上查询进度?
网站制作费用多少钱,一个网站的运营,需要哪些费用?
免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?
网站制作大概要多少钱一个,做一个平台网站大概多少钱?
网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?
建站之星安装后如何配置SEO及设计样式?
建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析
建站三合一如何选?哪家性价比更高?
上海网站制作开发公司,上海买房比较好的网站有哪些?
网站制作软件免费下载安装,有哪些免费下载的软件网站?
如何在腾讯云服务器上快速搭建个人网站?
网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?
如何快速启动建站代理加盟业务?
新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?
b2c电商网站制作流程,b2c水平综合的电商平台?
如何在阿里云虚拟主机上快速搭建个人网站?
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
免费网站制作appp,免费制作app哪个平台好?
,如何利用word制作宣传手册?
再谈Python中的字符串与字符编码(推荐)
如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?
C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)
打鱼网站制作软件,波克捕鱼官方号怎么注册?
免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?
如何配置支付宝与微信支付功能?
临沂网站制作企业,临沂第三中学官方网站?
香港网站服务器数量如何影响SEO优化效果?
在线教育网站制作平台,山西立德教育官网?
武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?
陕西网站制作公司有哪些,陕西凌云电器有限公司官网?
如何通过智能用户系统一键生成高效建站方案?
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
建站之星后台密码遗忘或太弱?如何重置与强化?
浅谈Javascript中的Label语句
制作网站的模板软件,网站怎么建设?
C++如何编写函数模板?(泛型编程入门)
C++时间戳转换成日期时间的步骤和示例代码
完全自定义免费建站平台:主题模板在线生成一站式服务
如何选择高效可靠的多用户建站源码资源?
微信小程序 input输入框控件详解及实例(多种示例)
Java解压缩zip - 解压缩多个文件或文件夹实例
建站之星如何快速生成多端适配网站?
简单实现Android文件上传
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
早安海报制作网站推荐大全,企业早安海报怎么每天更换?
广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?
开心动漫网站制作软件下载,十分开心动画为何停播?
如何用VPS主机快速搭建个人网站?
深圳网站制作平台,深圳市做网站好的公司有哪些?
*请认真填写需求信息,我们会在24小时内与您取得联系。