• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

vue组件中的数据传递方法

vue 搞代码 4年前 (2022-01-08) 23次浏览 已收录 0个评论

这篇文章主要介绍了vue组件中的数据传递方法,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧

Vue 的组件作用域都是孤立的,不允许在子组件的模板内直接引用父组件的数据。必须使用特定的方法才能实现组件之间的数据传递。组件之间传递数据大致分为三种情况:

父组件向子组件传递数据,通过 props 传递数据。

子组件向父组件传递数据,通过 events 传递数据。

两个同级组件之间传递数据,通过 event bus 传递数据。

一、父组件向子组件传递数据

子组件部分:

  <div class="child"> {{ msg }} </div>

在child.vue中,msg实在data中定义的变量,使用props:[‘msg’]从父组件中获取msg的值

父组件部分:

  <div class="child"> child </div>

在调用组件的时候,使用v-bind将msg的值绑定为parent.vue中定义的变量message,这样就能将parent.vue中的message的值传给child.vue了。

单项数据流

当父组件的 message 发生改变,子组件也会自动地更新视图。但是在子组件中,我们不要去修改 prop。如果你必须要修改到这些数据,你可以使用以下方法:

方法一:把 prop 赋值给一个局部变量,然后需要修改的话就修改这个局部变量,而不影响 prop

 export default { data(){ return { newMessage: null } }, props: ['message'], created(){ this.newMessage = this.message; } }

方法二:在计算属性中对 prop 进行处理

 export default { props: ['message'], computed: { newMessage(){ return this.message + ' 哈哈哈'; } } }

二、子组件向父组件传递数据

子组件主要通过实践传递数据给父组件的

子组件部分:

  <div class="child"> <span>用户名:</span></div>

子组件的html中,当input中的值发生改变时,将username传递给parent.vue。

首先声本文来源gao.dai.ma.com搞@代*码#网明了一个sendUser方法,用change事件来调用sendUser。

 

在sendUser中,使用$emit来遍历changeName事件,并返回this.name,其中changeName是一个自定义的事件,功能类似于一个中转,this.name将通过这个事件传递给父组件。

父组件部分:

  <div class="parent"> <p>用户名:{{user}}</p></div>

在父组件中声明了一个getUser方法,用changeName事件调用getUser方法,获取从子组件传递过来的参数username

 

getUser方法中的参数msg就是从子组件中传递过来的参数uesrname。

三、同级组件间的数据传递

有时候两个组件也需要通信(非父子关系)。当然Vue2.0提供了Vuex,但在简单的场景下,可以使用一个空的Vue实例作为中央事件总线。

  <div id="app">   //组件1  //组件2 </div>

组件c1中:

  <div class="c1"> page <button>click</button></div>

组件c2中:

  <div class="c2"> {{msg}} </div>

在实际运用中,一般将bus抽离出来:

 //Bus.js import Vue from 'vue' const Bus = new Vue() expore default Bus

组件调用时引用(import Bus from ‘./Bus.js’)

但这种引入方式,经过webpack打包后可能会出现Bus局部作用域的情况,即引用的是两个不同的Bus,导致不能正常通信
实际运用:

将Bus注入到Vue根对象中

 import Vue from 'vue' const Bus = new Vue() var app= new Vue({ el:'#app',    data:{     Bus }   })

在子组件中通过this.$root.Bus.$on(),this.$root.Bus.$emit()来调用

总结

以上就是vue组件中的数据传递方法的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:vue组件中的数据传递方法

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址