• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >vue > Vue.js父与子组件之间传参示例

Vue.js父与子组件之间传参示例

作者:成忠 字体:[增加 减小] 来源:互联网 时间:2017-05-30

本文主要包含vue子组件向父组件,vue父传子,vue 父组件,二龙湖浩哥之新父与子,父与子等相关知识,成忠 希望在学习及工作中可以帮助到您

例子:App.vue为父,引入componetA组件之后,则可以在template中使用标签(注意驼峰写法要改成componet-a写法,因为html对大小写不敏感,componenta与componentA对于它来说是一样的,不好区分,所以使用小写-小写这种写法)。而子组件componetA中,声明props参数'msgfromfa'之后,就可以收到父向子组件传的参数了。例子中将msgfromfa显示在<p>标签中。

App.vue中

 <component-a msgfromfa="(Just Say U Love Me)"></component-a> 
</div>
import componentA from './components/componentA'

export default {

new Vue({

components: {

componentA

}

})

} 
</div>

componentA.vue中

<p>{{ msgfromfa }}</p> 
</div>
export default {

props: ['msgfromfa']

} 
</div>

父向子组件传参(.$broadcast)

用法:vm.$broadcast( event, […args] )广播事件,通知给当前实例的全部后代。因为后代有多个枝杈,事件将沿着各“路径”通知。

例子:父组件App.vue中<input>绑定了键盘事件,回车触发addNew方法,广播事件”onAddnew”,并传参this.items。子组件componentA中,注册”onAddnew”事件,打印收到的参数items。

App.vue中

<div id="app">
<input v-model="newItem" @keyup.enter="addNew"/>
</div>
</div>
import componentA from './components/componentA'
export default {
new Vue({
methods: {
addNew: function() {
this.$broadcast('onAddnew', this.items)
}
}
})
}
</div>

componentA.vue中

import componentA from './components/componentA'

export default {

events: {

'onAddnew': function(items){

console.log(items)

}

}

} 
</div>

子组件向父传参(.$emit)

用法:vm.$emit( event, […args] ),触发当前实例上的事件。附加参数都会传给监听器回调。

例子:App.vue中component-a绑定了自定义事件”child-say”。子组件componentA中,单击按钮后触发”child-say”事件,并传参msg给父组件。父组件中listenToMyBoy方法把msg赋值给childWords,显示在<p>标签中。
App.vue中

<p>Do you like me? {{childWords}}</p>
<component-a msgfromfa="(Just Say U Love Me)" v-on:child-say="listenToMyBoy"></component-a>
</div>
import componentA from './components/componentA'
export default {
new Vue({
data: function () {
return {
childWords: ""
}
},
components: {
componentA
},
methods: {
listenToMyBoy: function (msg){
this.childWords = msg
}
}
})
}
</div>

componentA.vue中

<button v-on:click="onClickMe">like!</button>
</div>
import componentA from './components/componentA'
export default {
data: function () {
return {
msg: 'I like you!'
}
},
methods: {
onClickMe: function(){
this.$emit('child-say',this.msg);
}
}
}
</div>

子组件向父传参(.$dispatch)

用法:vm.$dispatch( event, […args] ),派发事件,首先在实例上触发它,然后沿着父链向上冒泡在触发一个监听器后停止。

例子:App.vue中events中注册”child-say”事件。子组件componentA中,单击按钮后触发”child-say”事件,并传参msg给父组件。父组件中”child-say”方法把msg赋值给childWords,显示在<p>标签中。

App.vue中

<p>Do you like me? {{childWords}}</p>
<component-a msgfromfa="(Just Say U Love Me)"></component-a>

</div>
import componentA from './components/componentA'
export default {
new Vue({
events: {
'child-say' : function(msg){
this.childWords = msg
}
}
})
}

</div>

componentA.vue中

<button v-on:click="onClickMe">like!</button>
</div>
import componentA from './components/componentA'
export default {
data: function () {
return {
msg: 'I like you!'
}
},
methods: {
onClickMe: function(){
this.$dispatch('child-say',this.msg);
}
}
}

</div>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

</div>

您可能想查找下面的文章:

  • Vue2.x中的父组件传递数据至子组件的方法
  • Vue.js父与子组件之间传参示例

相关文章

  • 2017-09-08vue2.0组件之间的通信
  • 2017-05-30vue从使用到源码实现教程详解
  • 2017-05-30Vue.js仿Metronic高级表格(二)数据渲染
  • 2017-05-30详解vue父子模版嵌套案例
  • 2017-05-30Vue.js render方法使用详解
  • 2017-05-30vue2.0开发实践总结之疑难篇
  • 2017-05-30利用vue实现模态框组件
  • 2017-05-30Vue数据驱动模拟实现2
  • 2017-05-30关于vue-router路径计算问题
  • 2017-05-30vue组件如何被其他项目引用

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • Vue.JS入门教程之自定义指令
    • Vue2.0实现1.0的搜索过滤器功能实例代码
    • vue+vuex+axio从后台获取数据存入vuex实现组件之间共享数据
    • 详解Vue中添加过渡效果
    • 详解vue-router 2.0 常用基础知识点之router.push()
    • vueJS简单的点击显示与隐藏的效果【实现代码】
    • Vue计算属性的学习笔记
    • vue数据双向绑定原理解析(get & set)
    • Vue.js组件tab实现选项卡切换
    • vue-router 中router-view不能渲染的解决方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有