组件间通信(父子,兄弟)

相关链接\组件通信:点击查看
学习链接:Vue.js——60分钟快速入门点击查看
分分钟玩转Vue.js组件点击查看
父组件传子组件
父传子方法(一) 属性传递 props
//子组件
<template>
<ul>
<li v-for="item in dataList">{{item}}</li>
</ul>
</template>
<script>
export default {
props : { dataList : [] }
}
</script>
//父组件
<template>
<component-child v-bind:data-list="dataList"> </component-child>
<input v-model="dataInput" v-on:keyup.13="addDataItem()" ></input>
</template>
<script>
import ComponentChild from './child.vue'
export default {
data () {
return {
dataInput: "",
dataList : [ 'hello world!','welcome to use vue.js' ]
}
},
components : { ComponentChild },
methods : {
addDataItem () {
let self = this
if( !(self.dataInput && self.dataInput.length > 0) ) { return }
self.dataList.push( self.dataInput )
self.dataInput = ""
}
}
}
</script>
父传子方法(二) 广播事件传递 vm.$broadcast
//子组件
<template>
<ul>
<li v-for="item in dataList">{{item}}</li>
</ul>
</template>
<script>
export default {
data () {
return {
dataList : [ 'hello world!', 'welcome to use vue.js' ]
}
},
events : {
addChildDataEvent : function ( dataInput ) {
this.dataList.push( dataInput )
}
}
}
</script>
//父组件
<template>
<component-child></component-child>
<input v-model="dataInput" v-on:keyup.13="addDataItem()" ></input>
</template>
<script>
import ComponentChild from './child.vue'
export default {
data () {
return { dataInput: "" }
},
components : { ComponentChild },
methods : {
addDataItem () {
let self = this
if( !(self.dataInput && self.dataInput.length > 0) ) { return }
//广播到子组件
self.$broadcast( 'addChildDataEvent', self.dataInput )
self.dataInput = "" }
}
}
</script>
子组件传父组件
子传父方法 派遣事件传递 vm.$dispatch
//子组件
<template>
<input v-model="dataInput" v-on:keyup.13="addDataItem()" ></input>
</template>
<script>
export default {
data () {
return {
dataInput: ""
}
},
methods : {
addDataItem () {
let self = this
if( !(self.dataInput && self.dataInput.length > 0) ) { return }
//派遣事件到父组件
self.$dispatch( 'addFatherDataEvent', self.dataInput )
self.dataInput = ""
}
}
}
</script>
//父组件
<template>
<ul>
<li v-for="item in dataList">{{item}}</li>
</ul>
<component-child></component-child>
</template>
<script>
import ComponentChild from './child.vue'
export default {
data () {
return {
dataList : [ 'hello world!', 'welcome to use vue.js' ]
}
},
components : { ComponentChild },
events : {
addFatherDataEvent : function ( dataInput ) {
this.dataList.push( dataInput )
}
}
}
</script>
兄弟组件互传
父组件代理传递 子(vm.dispatch )父 ( vm.broadcast )子 事件方法传递
<template>
<ul>
<li v-for="item in dataList">{{item}}</li>
</ul>
</template>
<script>
export default {
data () {
return {
dataList : [ 'hello world!', 'welcome to use vue.js' ]
}
},
events : {
addChildDataEvent : function ( dataInput ) {
this.dataList.push( dataInput )
}
}
}
</script>
<template>
<input v-model="dataInput" v-on:keyup.13="addDataItem()" ></input>
</template>
<script>
export default {
data () {
return { dataInput: "" }
},
methods : {
addDataItem () {
let self = this
if( !(self.dataInput && self.dataInput.length > 0) ) { return } //派遣事件到父组件
self.$dispatch( 'agentDataEvent', self.dataInput )
self.dataInput = ""
}
}
}
</script>
<template>
<component-child1></component-child1>
<component-child2></component-child2>
</template>
<script>
import ComponentChild1 from './child1.vue'
import ComponentChild2 from './child2.vue'
export default {
components : { ComponentChild1, ComponentChild2 },
events : {
agentDataEvent : function( dataInput ) {
this.$broadcast('addChildDataEvent', dataInput)
}
}
}
</script>
实例间通信
把实例当做参数传入另一个实例
<template>
<div>
<p>实例间通信</p>
<ul>
<li v-for="item in dataList">{{item}}</li>
</ul>
</div>
</template>
<script>
export default {
data () {
return {
dataList : [ 'hello world!', 'welcome to use vue.js' ]
}
},
events : {
addDataEvent : function ( dataInput ) {
this.dataList.push( dataInput )
}
}
}
</script>
<template>
<input v-model="dataInput" v-on:keyup.13="addDataItem()" ></input>
</template>
<script>
export default {
data () {
return {
dataInput: "",
otherApp : {}
}
},
methods : {
addDataItem ( ) {
let self = this
if( !(self.dataInput && self.dataInput.length > 0) ) { return } //触发其他实例事件
self.otherApp.$emit( 'addDataEvent', self.dataInput )
self.dataInput = ""
},
setOtherApp ( app ) {
this.otherApp = app
}
}
}
</script>
import Vue from "vue"
import App1 from "./communication5/app1.vue"
import App2 from "./communication5/app2.vue"
let AppVM1 = new Vue( App1 ).$mount('#app')
let AppVM2 = new Vue( App2 ).$mount('#app2')
AppVM2.setOtherApp( AppVM1 )
本文已被整理到了《Vue.js前端组件学习教程》,欢迎大家学习阅读。
关于vue.js组件的教程,请大家点击专题vue.js组件学习教程进行学习。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# vue组件间通信
# vue组件通信
# vue组件
# Vue.js每天必学之组件与组件间的通信
# vue之父子组件间通信实例讲解(props、$ref、$emit)
# vue2.0父子组件间通信的实现方法
# 详解Vue2中组件间通信的解决全方案
# Vue 父子组件、组件间通信
# vuejs事件中心管理组件间的通信详解
# vue组件间通信子与父详解(二)
# vue综合组件间的通信详解
# Vue.js组件间通信方式总结【推荐】
# Vue组件间通信方法总结(父子组件、兄弟组件及祖先后代组件间)
# 点击查看
# 已被
# 请大家
# 欢迎大家
# 相关链接
# 玩转
# 大家多多
# dataList
# item
# export
# script
# li
# template
# lt
# ul
# gt
# input
# list
# dataInput
# model
相关文章:
建站之星如何助力企业快速打造五合一网站?
如何在橙子建站中快速调整背景颜色?
,有什么在线背英语单词效率比较高的网站?
无锡营销型网站制作公司,无锡网选车牌流程?
如何快速启动建站代理加盟业务?
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
南宁网站建设制作定制,南宁网站建设可以定制吗?
购物网站制作公司有哪些,哪个购物网站比较好?
建站之星安全性能如何?防护体系能否抵御黑客入侵?
小捣蛋自助建站系统:数据分析与安全设置双核驱动网站优化
北京网页设计制作网站有哪些,继续教育自动播放怎么设置?
如何快速选择适合个人网站的云服务器配置?
如何正确选择百度移动适配建站域名?
浅谈Javascript中的Label语句
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?
python的本地网站制作,如何创建本地站点?
建站之家VIP精选网站模板与SEO优化教程整合指南
如何通过云梦建站系统实现SEO快速优化?
贸易公司网站制作流程,出口贸易网站设计怎么做?
建站VPS配置与SEO优化指南:关键词排名提升策略
如何在万网开始建站?分步指南解析
北京网站制作网页,网站升级改版需要多久?
南京网站制作费用,南京远驱官方网站?
天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?
建站之星伪静态规则如何设置?
如何快速完成中国万网建站详细流程?
专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?
如何选择适合PHP云建站的开源框架?
外汇网站制作流程,如何在工商银行网站上做外汇买卖?
公司网站设计制作厂家,怎么创建自己的一个网站?
非常酷的网站设计制作软件,酷培ai教育官方网站?
大连网站设计制作招聘信息,大连投诉网站有哪些?
如何在宝塔面板创建新站点?
如何通过西部建站助手安装IIS服务器?
营销式网站制作方案,销售哪个网站招聘效果最好?
大型企业网站制作流程,做网站需要注册公司吗?
番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?
如何在西部数码注册域名并快速搭建网站?
如何快速生成ASP一键建站模板并优化安全性?
建站之星如何实现五合一智能建站与营销推广?
公司门户网站制作流程,华为官网怎么做?
北京制作网站的公司,北京铁路集团官方网站?
php8.4新语法match怎么用_php8.4match表达式替代switch【方法】
建站之星如何助力网站排名飙升?揭秘高效技巧
广东企业建站网站优化与SEO营销核心策略指南
c# 服务器GC和工作站GC的区别和设置
如何通过VPS建站实现广告与增值服务盈利?
深圳防火门网站制作公司,深圳中天明防火门怎么编码?
浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?
*请认真填写需求信息,我们会在24小时内与您取得联系。