本文摘自PHP中文网,作者醉折花枝作酒筹,侵删。
本篇文章给大家详细介绍一下Vue常用的组件通信方式。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。组建通信的基本模式:父子组件的关系可以总结为 prop 向下传递,事件向上传递。父组件通过 prop 给子组件下发数据,子组件通过事件给父组件发送消息
组件通信的常用三种方式
1.props(父组件向子组件传值)
parent.vue
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | <template>
<p>
<parent-child :childName= "childName" ></parent-child>
</p>
</template>
<script>
import child from "./child"
export default {
components: {
"parent-child" : child
},data(){
return {
childName : "我是child哦"
}
}
}
</script>
|
child.vue
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | <template>
<p id= "child" >
child的名字叫:{{childName}}<br>
</p>
</template>
<script>
export default {
props:{
childName :{
type:String,
default : ""
}
}
}
</script>
|
2.$emit(子组件向父组件传值?C局部消息订阅)
parent.vue
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | <template>
<p>
<parent-child :childName= "childName" @childNotify= "childReceive" ></parent-child>
</p>
</template>
<script>
import child from "./child"
export default {
components: {
"parent-child" : child
},data(){
return {
childName : "我是child哦"
}
},methods:{
childReceive(params){
this .$message(params)
}
}
}
</script>
|
child.vue
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | < template >
< p id = "child" >
child的名字叫:{{childName}}< br >
</ p >
</ template >
< script >
export default {
props:{
childName :{
type:String,
default: ""
}
},methods:{
childNotify(params){
this.$emit("childNotify","child的名字叫"+this.childName);
}
}
}
</ script >
|
3.bus全局消息订阅
bus.js
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | const install = (Vue) => {
const Bus = new Vue({
methods: {
on (event, ...args) {
this. $on (event, ...args);
},
emit (event, callback) {
this. $emit (event, callback);
},
off (event, callback) {
this. $off (event, callback);
}
}
})
Vue.prototype. $bus = Bus;
}
export default install;
|
main.js
1 2 | import Bus from "./assets/js/bus" ;
Vue.use(Bus);
|
child.vue
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | <template>
<p id= "child" >
child的名字叫:{{childName}}<br>
<el-button type= "primary" @click= "brotherNotity" >向child 2 打招呼</el-button>
</p>
</template>
<script>
export default {
props:{
childName :{
type:String,
default: ""
}
},methods:{
childNotify(params){
this.$emit( "childNotify" , "child的名字叫" +this.childName);
},
brotherNotity(){
this.$bus.$emit( "child2" , "child2你好呀" );
}
}
}
</script>
|
child2.vue
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | <template>
<p id= "child2" >
child2的名字叫:{{child2Name}}
</p>
</template>
<script>
export default {
props:{
child2Name :{
type:String,
default : ""
}
},
created(){
this. $bus . $on ( "child2" , function (params){
this. $message (params)
})
},
beforeDestroy() {
this. $bus . $off ( "child2" , function (){
this. $message ( "child2-bus销毁" )
})
}
}
</script>
|
推荐学习:vue.js教程
以上就是Vue常用的组件通信方式的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
vue的优点是什么
vue.use是什么
在vue style中使用data中的变量的方法详解
浅谈vue.js中$refs的使用方法(附代码)
在 vue 中实现 echarts 随窗体变化
vue脚手架如何导入jquery第三方插件
vue和javascript的区别是什么
九大vuejs常见面试题,你都会吗?
vue中elementui是什么
怎么运行vue.js
更多相关阅读请进入《vue》频道 >>
人民邮电出版社
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者
转载请注明出处:木庄网络博客 » Vue常用的组件通信方式