对于vue来说,组件是非常常见的,有很多平台都封装了了属于自己一套的组件,如element ui、we ui等等。同时组件之间的消息传递也是非常重要的,下面是我对组件之间消息传递的各种方式的总结,共有8种方式。如有不足之处,可以留言补充,互相学习。

我们提供的服务有:网站制作、成都网站设计、微信公众号开发、网站优化、网站认证、寿光ssl等。为上千家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的寿光网站制作公司
1. props和$emit
这是最最常用的父子组件通信方式,父组件向子组件传递数据是通过prop传递的,子组件传递数据给父组件是通过$emit触发事件来做到的。 实例:
父组件
- Vue.component('parent',{
 - template:`
 父组件
- `,
 - data(){
 - return {
 - message:'Hello web秀'
 - }
 - },
 - methods:{
 - //执行子组件触发的事件
 - getChildData(val){
 - console.log(val)
 - }
 - }
 - })
 - var app=new Vue({
 - el:'#app',
 - template:`
 - `
 - })
 
子组件
- Vue.component('child',{
 - //得到父组件传递过来的数据
 - props:['message'],
 - data(){
 - return {
 - myMessage: this.message
 - }
 - },
 - template:`
 - `,
 - methods:{
 - passData(val){
 - //触发父组件中的事件
 - this.$emit('getChildData',val)
 - }
 - }
 - })
 
解析:
2. $attrs和$listeners
***种方式处理父子组件之间的数据传输有一个问题:如果多层嵌套,父组件A下面有子组件B,组件B下面有组件C,这时如果组件A想传递数据给组件C怎么办呢?
如果采用***种方法,我们必须让组件A通过prop传递消息给组件B,组件B在通过prop传递消息给组件C;要是组件A和组件C之间有更多的组件,那采用这种方式就很复杂了。从Vue 2.4开始,提供了$attrs和$listeners来解决这个问题,能够让组件A之间传递消息给组件C。
C组件
- Vue.component('C',{
 - template:`
 - `,
 - methods:{
 - passCData(val){
 - //触发父组件A中的事件
 - this.$emit('getCData',val)
 - }
 - }
 - })
 
B组件
- Vue.component('B',{
 - data(){
 - return {
 - myMessage:this.message
 - }
 - },
 - template:`
 - `,
 - //得到父组件传递过来的数据
 - props:['message'],
 - methods:{
 - passData(val){
 - //触发父组件中的事件
 - this.$emit('getChildData',val)
 - }
 - }
 - })
 
A组件
- Vue.component('A',{
 - template:`
 this is parent compoent!
- :messageC="messageC"
 - :message="message"
 - v-on:getCData="getCData"
 - v-on:getChildData="getChildData(message)">
 - `,
 - data(){
 - return {
 - message:'Hello',
 - messageC:'Hello c'
 - }
 - },
 - methods:{
 - getChildData(val){
 - console.log('这是来自B组件的数据')
 - },
 - //执行C子组件触发的事件
 - getCData(val){
 - console.log("这是来自C组件的数据:"+val)
 - }
 - }
 - })
 - var app=new Vue({
 - el:'#app',
 - template:`
 - `
 - })
 
解析:
3. v-model
父组件通过v-model传递值给子组件时,会自动传递一个value的prop属性,在子组件中通过this.$emit(‘input',val)自动修改v-model绑定的值
子组件
- Vue.component('child',{
 - props:{
 - //v-model会自动传递一个字段为value的prop属性
 - value: String,
 - },
 - data(){
 - return {
 - myMessage:this.value
 - }
 - },
 - methods:{
 - changeValue(){
 - //通过如此调用可以改变父组件上v-model绑定的值
 - this.$emit('input',this.myMessage);
 - }
 - },
 - template:`
 - type="text"
 - v-model="myMessage"
 - @change="changeValue">
 - `
 - })
 
父组件
- Vue.component('parent',{
 - template:`
 this is parent compoent!
{{message}}
- `,
 - data(){
 - return {
 - message:'Hello'
 - }
 - }
 - })
 - var app=new Vue({
 - el:'#app',
 - template:`
 - `
 - })
 
4. provide和inject
父组件中通过provider来提供变量,然后在子组件中通过inject来注入变量。不论子组件有多深,只要调用了inject那么就可以注入provider中的数据。而不是局限于只能从当前父组件的prop属性来获取数据,只要在父组件的生命周期内,子组件都可以调用。
子组件
- Vue.component('child',{
 - inject:['for'],//得到父组件传递过来的数据
 - data(){
 - return {
 - myMessage: this.for
 - }
 - },
 - template:`
 - `
 - })
 
父组件
- Vue.component('parent',{
 - template:`
 this is parent compoent!
- `,
 - provide:{
 - for:'test'
 - },
 - data(){
 - return {
 - message:'Hello'
 - }
 - }
 - })
 - var app=new Vue({
 - el:'#app',
 - template:`
 - `
 - })
 
5. 中央事件总线
上面方式都是处理的父子组件之间的数据传递,那如果两个组件不是父子关系呢?也就是兄弟组件如何通信?
这种情况下可以使用中央事件总线的方式。新建一个Vue事件bus对象,然后通过bus.$emit触发事件,bus.$on监听触发的事件。
- Vue.component('brother1',{
 - data(){
 - return {
 - myMessage:'Hello brother1'
 - }
 - },
 - template:`
 this is brother1 compoent!
- `,
 - methods:{
 - passData(val){
 - //触发全局事件globalEvent
 - bus.$emit('globalEvent',val)
 - }
 - }
 - })
 - Vue.component('brother2',{
 - template:`
 this is brother2 compoent!
brother1传递过来的数据:{{brothermessage}}
- `,
 - data(){
 - return {
 - myMessage:'Hello brother2',
 - brothermessage:''
 - }
 - },
 - mounted(){
 - //绑定全局事件globalEvent
 - bus.$on('globalEvent',(val)=>{
 - this.brothermessage=val;
 - })
 - }
 - })
 - //中央事件总线
 - var bus=new Vue();
 - var app=new Vue({
 - el:'#app',
 - template:`
 - `
 - })
 
6. parent和children
- Vue.component('child',{
 - props:{
 - value:String, //v-model会自动传递一个字段为value的prop属性
 - },
 - data(){
 - return {
 - mymessage:this.value
 - }
 - },
 - methods:{
 - changeValue(){
 - this.$parent.message = this.mymessage;//通过如此调用可以改变父组件的值
 - }
 - },
 - template:`
 - })
 - Vue.component('parent',{
 - template:`
 this is parent compoent!
- `,
 - methods:{
 - changeChildValue(){
 - this.$children[0].mymessage = 'hello';
 - }//在此我向大家推荐一个前端全栈开发交流圈:619586920 突破技术瓶颈,提升思维能力
 - },
 - data(){
 - return {
 - message:'hello'
 - }
 - }
 - })
 - var app=new Vue({
 - el:'#app',
 - template:`
 - `
 - })
 
7. boradcast和dispatch
vue1.0中提供了这种方式,但vue2.0中没有,但很多开源软件都自己封装了这种方式,比如min ui、element ui和iview等。 比如如下代码,一般都作为一个mixins去使用, broadcast是向特定的父组件,触发事件,dispatch是向特定的子组件触发事件,本质上这种方式还是on和on和emit的封装,但在一些基础组件中却很实用。
- function broadcast(componentName, eventName, params) {
 - this.$children.forEach(child => {
 - var name = child.$options.componentName;
 - if (name === componentName) {
 - child.$emit.apply(child, [eventName].concat(params));
 - } else {
 - broadcast.apply(child, [componentName, eventName].concat(params));
 - }
 - });
 - }
 - export default {
 - methods: {
 - dispatch(componentName, eventName, params) {
 - var parent = this.$parent;
 - var name = parent.$options.componentName;
 - while (parent && (!name || name !== componentName)) {
 - parentparent = parent.$parent;
 - if (parent) {
 - name = parent.$options.componentName;
 - }
 - }
 - if (parent) {
 - parent.$emit.apply(parent, [eventName].concat(params));
 - }
 - },
 - broadcast(componentName, eventName, params) {
 - broadcast.call(this, componentName, eventName, params);
 - }
 - }
 - };
 
8. vuex处理组件之间的数据交互
如果业务逻辑复杂,很多组件之间需要同时处理一些公共的数据,这个时候才有上面这一些方法可能不利于项目的维护,vuex的做法就是将这一些公共的数据抽离出来,然后其他组件就可以对这个公共数据进行读写操作,这样达到了解耦的目的。
                新闻名称:8种vue组件通信方式详细解析实例
                
                网页地址:http://www.csdahua.cn/qtweb/news39/409689.html
            
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网