组件通信的几种方式-M

组件通信的几种方式

父组件向子组件传值

在父组件中用自定义组件进行传值,自定义属性写到父组件调用子组件的那个标签中。在子组件中用props进行接收,props写到子组件中与data同级,props是一个数组,内容就是自定义属性的名字。
在这里插入图片描述

在这里插入图片描述

子组件向父组件进行传值

子组件向父组件传值用的是发布订阅者模式,在子组件中用this.$emit发布一个自定义事件,接收两个参数,第一个参数是自定义事件的事件名,第二个参数是要传递的值。在父组件调用子组件的标签中用@自定义的事件名=“回调函数”,回调函数中传来几个数据,就用几个参数进行接收。
在这里插入图片描述

vuex(下篇中细讲)

父组件调用子组件中的方法

方法一:
在父组件调用子组件的标签中,通过ref直接调用子组件中的方法,ref等于一个变量如childChange,在父组件的方法中用this.$refs.childChange.子组件中的方法来实现。

//父组件中
<template>
    <div>
        <Button @click="handleClick">点击调用子组件方法</Button>
        <Child ref="childChange"/>
    </div>
</template>    
 
<script>
import Child from './child';
 
export default {
    
    
    methods: {
    
    
        handleClick() {
    
    
              this.$refs.childChange.sing();
        },
    },
}
</script>
 
 
//子组件中
<template>
  <div>我是子组件</div>
</template>
<script>
export default {
    
    
  methods: {
    
    
    sing() {
    
    
      console.log('子组件的方法');
    },
  },
};
</script>

方法二:
通过组件的 e m i t 、 emit、 emiton方法来实现

//父组件中
<template>
    <div>
        <Button @click="handleClick">点击调用子组件方法</Button>
        <Child ref="child"/>
    </div>
</template>    
<script>
import Child from './child';
export default {
    
    
    methods: {
    
    
        handleClick() {
    
    
            this.$refs.child.$emit("childmethod") //子组件$on中的名字
        },
    },
}
</script>
 
//子组件中
<template>
    <div>我是子组件</div>
</template>
<script>
export default {
    
    
    mounted() {
    
    
        this.$nextTick(function() {
    
    
            this.$on('childmethods', function() {
    
    
                console.log('子组件的方法');
            });
        });
     },
};
</script>

子组件调用父组件的方法

方法一:
直接在子组件中通过this.$parent.event来调用父组件的方法

//父组件中
<template>
    <div>
        <Child></Child>
    </div>
</template>    
<script>
import Child from './child';
export default {
    
    
    methods: {
    
    
        fatherMethod() {
    
    
            console.log('父组件中的方法');
        },
    },
}
</script>
 
//子组件中
<template>
    <div>
		<Button @click="childMethod">子组件调用父组件中的方法</Button>
	</div>
</template>
<script>
export default {
    
    
    mounted() {
    
    
        childMethod() {
    
    
          this.$parent.fatherMethod();
        }
     },
};
</script>

方法二:
在子组件里用$emit向父组件触发一个事件,父组件监听这个事件就行了。

//父组件中
<template>
    <div>
        <Child @fatherMethod="fatherMethod"></Child>
    </div>
</template>    
<script>
import Child from './child';
export default {
    
    
    methods: {
    
    
        fatherMethod() {
    
    
            console.log('父组件中的方法');
        },
    },
}
</script>
 
//子组件中
<template>
    <div>
		<Button @click="childMethod">子组件调用父组件中的方法</Button>
	</div>
</template>
<script>
export default {
    
    
    mounted() {
    
    
        childMethod() {
    
    
          this.$emit('fatherMethod');
        }
     },
};
</script>

方法三:
父组件把方法传入子组件中,在子组件里直接调用这个方法

//父组件中
<template>
    <div>
        <Child @fatherMethod="fatherMethod"></Child>
    </div>
</template>    
<script>
import Child from './child';
export default {
    
    
    methods: {
    
    
        fatherMethod() {
    
    
            console.log('父组件中的方法');
        },
    },
}
</script>
 
//子组件中
<template>
    <div>
		<Button @click="childMethod">子组件调用父组件中的方法</Button>
	</div>
</template>
<script>
export default {
    
    
    props: {
    
    
      fatherMethod: {
    
    
        type: Function,
        default: null
      }
    },
    mounted() {
    
    
        childMethod() {
    
    
          if (this.fatherMethod) {
    
    
	          this.fatherMethod();
	      }
        }
     },
};
</script>

猜你喜欢

转载自blog.csdn.net/Sunshinedada/article/details/130602478