Vue怎么通过$emit方法实现子父组件通信
本篇内容介绍了“Vue怎么通过$emit方法实现子父组件通信”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
成都创新互联公司于2013年开始,先为霍邱等服务建站,霍邱等地企业,进行企业商务咨询服务。为霍邱企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。
Vue可以通过props属性,将参数从父组件传递给子组件,相对而言是比较简单的。
如果是想从子组件传递参数到父组件的话,得借助父组件的方法,同时在子组件中通过$emit来调用父组件中的方法实现。
接下来具体演示下。
场景
同样情况,父组件是新闻列表组件,子组件是新闻内容组件。在子组件中点击删除按钮,可以将删除的新闻信息传递给父组件,从而实现新闻列表的更新。
父组件开发
父组件用来显示新闻列表,代码如下:
有几个需要注意的点:
在父组件中注册了子组件
NewsContent
在父组件中定义了删除新闻的方法,当传递的新闻标题与作者均匹配时,则从新闻列表list中删除对应的新闻。
通过
:news="item"
,将父组件的参数传递给子组件。通过
@removeNews="removeNews"
,将父组件的方法传递给子组件,注意子组件就是通过该方法来调用父组件方法并传参的。
子组件开发
子组件通过$emit
调用父组件传递过来的removeNews
方法,代码如下:
新闻标题:{{news.title}}--新闻作者:{{news.author}}
注意,当点击新闻后面的删除按钮时,触发btnDelete方法,而btnDelete方法内容为this.$emit("removeNews", news);
,即调用了父组件的removeNews方法,且传递参数news。
所以点击子组件删除按钮后,父组件中对应的新闻被删除。
子组件调用父组件的方法,来实现子父组件通信。父组件需要先将方法传递给子组件,子组件在通过$emit调用传递的方法,并不算很复杂。
1.props
和$attrs
具有数据的单向性,只能由父组件向子组件传递数据,不具备子传父的功能。
2.在vue
中,我们可以使用自定义事件实现子组件向父组件传递数据。
自定义事件
1.在子组件上使用v-on
指令绑定自定义事件
getChildData(data){ //data是子组件触发事件传递的参数 console.log('child data is' +data) }
2.事件的名称推荐使用-
分割
$emit
触发事件
1.每一个组件实例都要$emit
方法用来触发自定义事件。
2.$emit(fn,arg)
接受两个参数
(1)第一个参数是触发的事件名称,注意必须和定义的事件名完全相同。
(2)第二个参数是向父组件传递的数据。在父组件中就是定义的事件函数的第一个参数。
this.$emit('get-child-data','hello father')
“Vue怎么通过$emit方法实现子父组件通信”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!
分享文章:Vue怎么通过$emit方法实现子父组件通信
分享URL:http://pwwzsj.com/article/jccjep.html