Vue 的单文件组件在使用 Vue 时很是经常使用,因此咱们也会常常遇到组件之间须要传递数据的时候,大体分为三种状况:html
父组件向子组件传递数据,经过 props 传递数据。前端
子组件向父组件传递数据,经过 events 传递数据。vue
两个同级组件之间传递数据,经过 event bus 传递数据。app
文档中也已经详细的说明了各类状况下的解决方法,可是如今我在尚未阅读多少文档的状况下,没有找到有单文件组件方面的具体书写方式,智商和理解能力有限的状况下,本身尝试了一下,最后发现实际上是同样的。因此这篇文章实际上是废话,可是仍是想记录一下,不枉本身花了一个多小时。this
准备工做,我新建了 6 个文件,分别是:code
index.htmlcomponent
main.js 「Vue 实例」htm
app.vue 「根组件,包含 page 和 footer 组件」事件
page.vue 「msg 的父组件,footer 的 同级组件」ip
msg.vue
footer.vue
这里我以 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> <style> </style>
msg.vue 中
<template> <div class="msg"> {{ love }} </div> </template> <script> export default { name: 'msg', props: ['love'] } </script> <style> </style>
这样之后就会发现,实现了把父组件 page 中的数据传递到子组件 msg 中了。
另外,须要强调一下的是,不要在子组件中修改 props 的值,固然修改是有效的,很是不推荐,并且 Vue 也会有警告提示。正确的作法是传递给 data 中的属性或者计算属性。props 中的值是能够经过 this.love 访问到的。
特别注意 props 值是引用类型时的状况,不能够进行简单的赋值,会影响到父组件,正确的作法是进行深拷贝。
父组件 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> <style> </style>
子组件 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> <style> </style>
点击后就会发现 console 出了 'success'。
须要引入一个 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> <style> </style>
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> <style> </style>
嗯,最后发现打印出来了 '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) => { //... }) } }
嗯,废话较多,毫无干货。做为刚进入前端行业,刚开始写博客的新人,缺点和不足麻烦你们指出。转载请注明出处。