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

相关链接\组件通信:点击查看
学习链接: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
相关文章:
如何彻底删除建站之星生成的Banner?
临沂网站制作公司有哪些,临沂第四中学官网?
南京网站制作费用,南京远驱官方网站?
香港网站服务器数量如何影响SEO优化效果?
如何通过虚拟主机快速完成网站搭建?
公司网站的制作公司,企业网站制作基本流程有哪些?
佛山网站制作系统,佛山企业变更地址网上办理步骤?
如何解决VPS建站LNMP环境配置常见问题?
如何选择高效便捷的WAP商城建站系统?
如何基于PHP生成高效IDC网络公司建站源码?
如何选择高效稳定的ISP建站解决方案?
建站之星代理商如何保障技术支持与售后服务?
制作网站公司那家好,网络公司是做什么的?
企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?
南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?
建站之星安装后如何配置SEO及设计样式?
巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成
浅谈Javascript中的Label语句
如何注册花生壳免费域名并搭建个人网站?
制作营销网站公司,淘特是干什么用的?
正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?
如何快速搭建高效WAP手机网站吸引移动用户?
如何高效利用亚马逊云主机搭建企业网站?
建站之星如何保障用户数据免受黑客入侵?
如何解决ASP生成WAP建站中文乱码问题?
深圳网站制作费用多少钱,读秀,深圳文献港这样的网站很多只提供网上试读,但有些人只要提供试读的文章就能全篇下载,这个是怎么弄的?
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
深圳网站制作培训,深圳哪些招聘网站比较好?
如何选择建站程序?包含哪些必备功能与类型?
官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站
如何通过建站之星自助学习解决操作问题?
常州自助建站工具推荐:低成本搭建与模板选择技巧
猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?
建站之星如何实现PC+手机+微信网站五合一建站?
公司网站制作价格怎么算,公司办个官网需要多少钱?
高端网站建设与定制开发一站式解决方案 中企动力
网站设计制作公司地址,网站建设比较好的公司都有哪些?
如何选择美橙互联多站合一建站方案?
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
建站主机与虚拟主机有何区别?如何选择最优方案?
Swift中switch语句区间和元组模式匹配
建站之星免费版是否永久可用?
广德云建站网站建设方案与建站流程优化指南
如何通过商城自助建站源码实现零基础高效建站?
家具网站制作软件,家具厂怎么跑业务?
建站之星安装后如何自定义网站颜色与字体?
Android使用GridView实现日历的简单功能
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
如何选择网络建站服务器?高效建站必看指南
*请认真填写需求信息,我们会在24小时内与您取得联系。