Vue 单文件中的数据传递示例
Vue 的单文件组件在使用 Vue 时非常常用,所以我们也会经常遇到组件之间需要传递数据的时候,大致分为三种情况:
文档中也已经详细的说明了各种情况下的解决方法,但是现在我在还没有阅读多少文档的情况下,没有找到有单文件组件方面的具体书写方式,智商和理解能力有限的情况下,自己尝试了一下,最后发现其实是一样的。所以这篇文章其实是废话,但是还是想记录一下,不枉自己花了一个多小时。 准备工作,我新建了 6 个文件,分别是:
父组件向子组件传递数据,通过 props 传递数据。这里我以 page 向 msg 传递数据为例:page.vue 中 msg.vue 中 这样以后就会发现,实现了把父组件 page 中的数据传递到子组件 msg 中了。 另外,需要强调一下的是,不要在子组件中修改 props 的值,当然修改是有效的,非常不推荐,而且 Vue 也会有警告提示。正确的做法是传递给 data 中的属性或者计算属性。props 中的值是可以通过 this.love 访问到的。 特别注意 props 值是引用类型时的情况,不可以进行简单的赋值,会影响到父组件,正确的做法是进行深拷贝。 子组件向父组件传递数据,通过 events 传递数据。父组件 page.vue 中 子组件 msg.vue 中 点击后就会发现 console 出了 'success'。 同级元素之间传递数据,通过 event bus 来传递。需要引入一个 Vue 实例 作为中央总线。page 组件中 footer 组件中 嗯,最后发现打印出来了 '666',这样就实现了。 最后总结一下:父组件向子组件传递数据,通过 props 传递数据。具体做法只需要在父组件中绑定,在子组件中声明。 //子组件 子组件向父组件传递数据,通过 events 传递数据。具体做法时在父组件中监听,在子组件中触发。 //子组件 两个同级组件之间传递数据,通过 event bus 传递数据。 //触发事件
export default { ... methods: { passData () { this.$emit('communicate','hello') } } } //监听事件 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- ruby-on-rails – 我正在使用RVM,使用bundle install和rvm
- c# – 错误提供程序没有统一闪烁
- ruby – 当前月份第一天最有效的方法是什么?
- c# – 如何取消NetworkStream.ReadAsync而不关闭流
- Oracle SQL生成嵌套的xml
- 如何在Oracle SQL开发工具中运行.sql文件导入数据库?
- ruby-on-rails-3 – Rails 3简单形式bootstrap Radio和复选
- webview – 如何在React Native应用程序中集成G??oogle的re
- c# – SQLite在多用户本地网络环境中的性能不佳问题
- XML编程实例--对xml配置文件中的数据进行增、删、改、查