一、安装消息订阅插件:pubsub-js
data:image/s3,"s3://crabby-images/89872/898722f11d4877751387ebdd78a0e62b08571807" alt=""
二、效果图
data:image/s3,"s3://crabby-images/e9a53/e9a537f2dcc264f436064eec570de1e601b913c0" alt=""
三、School.vue(发送消息)
data:image/s3,"s3://crabby-images/f0e0c/f0e0c6152befd24a173cab8aa0a63d407e1110d6" alt=""
?
<template>
<!-- 组件一 -->
<div class="demo">
<h2>-----【School.vue】子组件-----</h2>
<h2>学校名称:{{ schoolName }}</h2>
<h2>学校地址:{{ address }}</h2>
<button @click="showName1">点击传给Student组件</button>
</div>
</template>
<script>
import pubsub from "pubsub-js";
// 把组件暴露出去,方便引入 Vue.extend可以省略
export default {
// eslint-disable-next-line vue/multi-word-component-names
name: "School",
data() {
return {
schoolName: "清华大学",
address: "北京",
};
},
methods: {
showName1() {
pubsub.publish('messageOrder',[this.schoolName,this.address])
},
},
};
</script>
<style scoped>
.demo {
background-color: antiquewhite;
border: 1px red solid;
padding-left: 10px;
height: 250px;
width:400px;
}
button{
width:300px;
height: 50px;
/* background-color: antiquewhite; */
font-size: 22px;
}
</style>
四、Student.vue(自动接收消息)
data:image/s3,"s3://crabby-images/d8c61/d8c61f00860c9739815f3e3b9bb06bd84001b506" alt=""
?
|