Vue 单文件中的数据传递
来源:互联网 发布:文件粉碎软件 编辑:程序博客网 时间:2024/06/15 21:43
Vue 的单文件组件在使用 Vue 时非常常用,所以我们也会经常遇到组件之间需要传递数据的时候,大致分为三种情况:
- 父组件向子组件传递数据,通过 props 传递数据。
- 子组件向父组件传递数据,通过 events 传递数据。
- 两个同级组件之间传递数据,通过 event bus 传递数据。
新建了 6 个文件,分别是:
- index.html
- main.js 「Vue 实例」
- app.vue 「根组件,包含 page 和 footer 组件」
- page.vue 「msg 的父组件,footer 的 同级组件」
- msg.vue
- footer.vue
父组件向子组件传递数据,通过 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><style></style>
这样以后就会发现,实现了把父组件 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><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'。
同级元素之间传递数据,通过 event bus 来传递。
需要引入一个 Vue 实例 作为中央总线。page 组件中
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 传递数据。具体做法只需要在父组件中绑定,在子组件中声明。
子组件向父组件传递数据,通过 events 传递数据。具体做法时在父组件中监听,在子组件中触发。
两个同级组件之间传递数据,通过 event bus 传递数据。
阅读全文
0 0
- Vue 单文件中的数据传递
- vue 数据传递
- vue 数据传递
- vue单文件组件
- vue.js 单文件组件 .vue文件
- 单文件组件.vue 文件
- vue单页面兄弟组件信息传递
- vue 单文件组件 *.vue 组件
- 关于单文件组件.vue
- vue.js中的子组件与父组件,prop传递数据
- vue父子组件的数据传递
- vue.js使用props传递数据
- vue.js实现数据传递的demo
- Vue---组件之间的数据传递
- vue.js 组件之间传递数据
- vue组件中数据的传递
- Vue.js学习笔记:props传递数据
- vue 1.x 组件数据传递
- chapter13_4图片的高级融合
- 在线教育最新数据公布,我们看到了几大明显信号
- 线程间通信
- html笔记——html空格:HTML中      等6种空白空格的区别
- Unity 3D项目问题笔记 //03_unity 中的 Toggle 问题
- Vue 单文件中的数据传递
- 跟着姜少学Java基础编程之一:数据类型
- php文字插入数据库乱码取出正常问题
- [RK3288][Android6.0] AUDIO_BECOMING_NOISY作用
- Mac Shell脚本中使用echo的-n参数不生效
- 数据结构--希尔排序(ShellSort)思想与实现
- 第十三节:下拉选择框Select
- linux环境程序在链接时和运行时搜索动态库的顺序
- HDU 4757 树链剖分+可持久化字典树