Vue父组件与子组件传递事件/调用事件

父组件:

<template>
<div>
<div @click="openChild">弹弹弹,弹出子组件</div>
<childs ref="alert" @watchChild="parentReceive"></childs> <!--监听子组件绑定的方法-->
</div>
</template>

<script>
import childs from ‘../components/modal/Alert‘
export default{
data(){
return {
msg: ‘我是父组件的msg!!!‘
}
},
components:{
childs
},
methods:{
parentReceive(message){
alert(message);
},
openChild(){
this.$refs.alert.open(‘我是子组件‘,‘子组件内容!!!!!‘);
}
}
}
</script>

<style>
</style>
子组件:

<template>
<modal :show=‘show‘ ref="modal">
<div slot="title">{{title}}</div>
<div slot="content">{{content}}</div>
<div slot="buttons" class="modal-buttons">
<span class="modal-button" @click="_onClick()">确定</span>
</div>
</modal>
</template>

<script>
import Modal from ‘./Modal‘

export default {
props: {
show: {
type: Boolean,
default: false
},
okText: {
type: String,
default: ‘确定‘
},
},
data(){
return {
title: ‘‘,
content: ‘‘
}
},
components: {
Modal
},
methods: {
open (title, content) {
this.title = title
this.content = content
this.$refs.modal.open()
},
close () {
this.title = ‘‘
this.content = ‘‘
this.$refs.modal.close()
},
_onClick(){
this.close();
this.$emit(‘watchChild‘,‘我是从子组件传过来的内容!!!‘);    //触发$emit绑定的watchChild方法
}
}
}
</script>
第一种方法:

如上:通过this.$emit()来触发父组件的方法。具体就是子组件触发$emit绑定的事件watchChild,然后父组件监听watchChild,一旦watchChild被触发便会触发父组件的parentReceive方法。

父组件:

<template>
<div>
<div @click="openChild">弹弹弹,弹出子组件</div>
<childs ref="alert" :on-ok="parentReceive"></childs> <!--把父组件的方法名传给子组件的onOK属性-->
</div>
</template>

<script>
import childs from ‘../components/modal/Alert‘
export default{
data(){
return {
msg: ‘我是父组件的msg!!!‘
}
},
components:{
childs
},
methods:{
parentReceive(message){
alert(message);
},
openChild(){
this.$refs.alert.open(‘我是子组件‘,‘子组件内容!!!!!‘);
}
}
}
</script>

<style>
</style>
子组件:

<template>
<modal :show=‘show‘ ref="modal">
<div slot="title">{{title}}</div>
<div slot="content">{{content}}</div>
<div slot="buttons" class="modal-buttons">
<span class="modal-button" @click="_onClick()">确定</span>
</div>
</modal>
</template>

<script>
import Modal from ‘./Modal‘

export default {
props: {
show: {
type: Boolean,
default: false
},
okText: {
type: String,
default: ‘确定‘
},
onOk: {    //定义onOK属性
type: Function
}
},
data(){
return {
title: ‘‘,
content: ‘‘
}
},
components: {
Modal
},
methods: {
open (title, content) {
this.title = title
this.content = content
this.$refs.modal.open()
},
close () {
this.title = ‘‘
this.content = ‘‘
this.$refs.modal.close()
},
_onClick(){
this.close();
if(this.onOk){
this.onOk(‘我是子组件传递过来的数据!!!!‘);
}
}
}
}
</script>
第二种方法:

在子组件props中定义属性onOK,类型为function,然后在父组件中把要触发的方法名传递给onOK属性,最后在子组件中判断onOk是否存在,是的话直接执行这个方法。

效果:

---------------------
作者:yemuxia_sinian
来源:CSDN
原文:https://blog.csdn.net/yemuxia_sinian/article/details/80534296
版权声明:本文为博主原创文章,转载请附上博文链接!

原文地址:https://www.cnblogs.com/shaozhu520/p/10729477.html

时间: 2024-08-03 12:19:43

Vue父组件与子组件传递事件/调用事件的相关文章

vue父页面给子页面传递数据

父页面: <template> <div>{{msg}} <Son title='向子文件传递数据' :data='data' :lifemsg ='lifemsg' :num='num'/> <button @click="chageMsg">修改数据</button> <input type="text" v-model="lifemsg" /> </div>

Vue父组件向子组件传递方法(自定义方法)并且子组件向父组件传递数据

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" con

vue组件-#构成组件-父组件向子组件传递数据

组件对于vue来说非常重要,学习学习了基础vue后,再回过头来把组件弄透! 一.概念 组件意味着协同工作,通常父子组件会是这样的关系:组件 A 在它的模版中使用了组件 B . 它们之间必然需要相互通信:父组件要给子组件传递数据,子组件需要将它内部发生的事情告知给父组件. 在 Vue.js 中,父子组件的关系可以总结为 props down, events up . 父组件通过 props 向下传递数据给子组件,子组件通过 events 给父组件发送消息. 看看它们是怎么工作的.        

Vue父组件向子组件传递一个动态的值,子组件如何保持实时更新实时更新?

原文:https://blog.csdn.net/zhouweixue_vivi/article/details/78550738 2017年11月16日 14:22:50 zhouweixue_vivi 阅读数:29918 最近用vue做一个新项目,经历了各种折磨,每次遇到问题都想大喊,格劳资上JQuery,氮素肯定是不行的,今天遇到一个小问题,Vue父组件向子组件传递一个动态的值,子组件只能获取初始值,不能实时更新? 这就有点折磨人了,设想的是,父组件发生变化获取数据,动态传递给子组件,子组

vue--父组件向子组件传参--父组件定义v-bind:参数名--子组件接收props----子组件调用父组件的方法(子组件向父组件传参)父组件@事件名称--子组件接收this.$emit

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" con

Vue子组件向父组件通信,父组件向子组件通信

首先,子组件代码如下 <template> <div style="border:1px solid black;width:400px;"> <h3>我是子组件里的</h3> <button>点击按钮子组件传递父组件</button> <div>我是父组件传子组件显示的:我还没有值</div> </div> </template> <script> ex

vue中父组件向子组件传值(方法)

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>父组件把方法传递给子组件</title> <script src="./vue2.6.9.js"></script> </head> <body> <div id="app&

Vue的父子组件v-model双向绑定,父组件修改子组件中绑定的v-model属性

先来看下实现的效果,父组件中有个文本框,在点击下面按钮时弹出抽屉,抽屉里也有个文本框,文本框里的初始值要和父组件的文本框同步,并且修改抽屉里的文本框值时 父组件里的文本框值也要跟着改变 网上有大概三种方法 父组件调用子组件传值,子组件通过props接收父组件传来的值,并通过emit发送方法名和值,父组件根据传来的方法名定义方法接收值并进行赋值操作. Sync  这个没试过不了解 v-model  子传父: 父组件定义v-model,子组件中当数据更新时,向父组件emit一个input事件,将更新

Vue中,父组件向子组件传值

1:在src/components/child/文件夹下,创建一个名为:child.vue的子组件 2:在父组件中,设置好需要传递的数据 3:在App.vue中引入并注册子组件 4:通过v-bind属性绑定并赋值给子组件 5:子组件通过 props 接收父组件传递过的数据 6:查看 7:总结: 子组件在props中创建一个属性,用以接收父组件传过来的值 父组件中注册子组件 在子组件标签中添加子组件props中创建的属性 把需要传给子组件的值赋给该属性 原文地址:https://www.cnblo

Vue 父组件与子组件之间传值

一.父组件与子组件之间值传递步骤如下: 例如:我有一个父组件Myhome.vue 和一个子组件Header.vue 1.父组件调用子组件的时候,动态绑定属性值 <v-myheader :title="title"></v-myheader> 2.在子组件使用 props 来接受父组件传过来数据(props:['title']),如果是多个就定义多个属性就可以 完整代码如下: 1.Myhome.vue(父组件)代码如下: <template> <