vue父子组件通信实现过程

父组件->子组件

		<!-- 将父组件中的number传入子组件中 -->
		<div id="app">
			<child-a :a='number'></child-a>
		</div>
		<script>
			Vue.component('child-a', {
				template:`<p>我是一个子组件</p>`,
				props:['a'],
				//props:字符串数组
				//props中的数据的值来源于父组件
				//props数据中的用法和data中的数据用法完全一样
				//同时props中的数据也相当于该组件的属性,所以就可以传入父组件中data的值
			})
			var vm = new Vue({
				el:'#app',
				data:{
					number:200
				}
			})
		</script>

子组件->父组件

<!-- 通过this.$emit调用父组件的方法来向父组件传递参数 -->
		<div id="app">
			//定义一个事件 来让子组件调用事件方法
			<child2 @func='show'></child2>
		</div>
		//子组件模板
		<template id="tmpl">
			<div>
				<h1>这是子组件</h1>
				<input type="button" @click="myclick" value="" />
			</div>
		</template>
		
		<script>
			var child2 = {
				template:'#templ',
				data(){
					return {
						msg:'我是子组件的数据'
					}
				}
				methods:{
					myclick(){
						//当点击子组件的按钮时,调用父组件里的show方法并把子组件里的数据传入父组件
						//第一个参数是事件名称,之后添加的参数可以当作实参数据传入父组件的方法中
						this.$emit('func', this.msg)
					}
				}
			}
		  var vm = new Vue({a
				el:'#app',
				data:{
					number:200
				},
				methods: {
					show(data){
						console.log('调用了父组件身上的方法:-------'+ data)
					}
				}
				components:{
					child2
				}
			})
		</script>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue组件通信可以分为父子组件通信和兄弟组件通信。下面是 Vue 父子组件通信过程: 1. 父组件通过 props 将数据传递给子组件。 2. 子组件通过 $emit 触发一个自定义事件,并传递数据给父组件。 3. 父组件监听子组件触发的自定义事件,并在自定义事件的回调函数中处理数据。 具体实现步骤如下: 1. 在父组件中定义一个数据属性,然后将这个数据属性通过 props 传递给子组件。 2. 子组件通过 props 接收父组件传递的数据。 3. 在子组件中定义一个方法,并通过 $emit 触发一个自定义事件,并将数据传递给父组件。 4. 在父组件中监听子组件触发的自定义事件,并在自定义事件的回调函数中处理数据。 例如: ``` // Parent.vue <template> <div> <child :message="msg" @send="handleSend"></child> </div> </template> <script> import Child from './Child.vue' export default { components: { Child }, data() { return { msg: 'Hello World!' } }, methods: { handleSend(data) { console.log(data) } } } </script> // Child.vue <template> <div> {{ message }} <button @click="sendMessage">Send Message</button> </div> </template> <script> export default { props: ['message'], methods: { sendMessage() { this.$emit('send', 'Hello Parent!') } } } </script> ``` 在上面的例子中,父组件通过 props 将数据属性 `msg` 传递给子组件,子组件接收到数据属性并显示。当子组件点击按钮时,会触发 `sendMessage` 方法,并通过 `$emit` 触发自定义事件 `send`,并将数据 `'Hello Parent!'` 传递给父组件。父组件监听自定义事件 `send`,并在回调函数中处理数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值