组件通信的几种方式
父组件向子组件传值
在父组件中用自定义组件进行传值,自定义属性写到父组件调用子组件的那个标签中。在子组件中用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、
emit、on方法来实现
//父组件中
<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>