vue中父子组件传值Prop&$emit

一、组件之间的传值方式有哪些?
①父组件传值给子组件,子组件使用props进行接收
②子组件传值给父组件,子组件使用 e m i t + 事 件 对 父 组 件 进 行 传 值 ③ 使 用 emit+事件对父组件进行传值 ③使用 emit+使 a t t r s 和 attrs和 attrschildren获取到父组件实例和子组件实例,进而获取数据
④使用attrs和$listeners,在对一些组件进行二次封装时可以方便传值,例如A->B->C
⑤使用refs获取组件实例,进而获取数据
⑥使用vuex进行状态管理
⑦使用eventBus进行跨组件触发事件,进而传递数据
⑧使用provide和inject,官方建议不要使用这个
⑨使用浏览器本地缓存,例如localstorage
二、详细讲解vue中父子组件传值
1、父组件向子组件传值

//父组件.vue
<template>
	<div>
		<Child name="张三" sex="女" :age="18" />
	</div>
</template>
<script>
	import Child from './components/Child'
	export default{
		name:"Parent",
		conponents:{Child}
	}
</script>
//子组件.vue
<template>
	<div>
		<h2>姓名:{{name}}</h2>
		<h2>性别:{{sex]}</h2>
		<h2>年龄:{{age}}</h2>
	</div>
</template>
<script>
	export default{
		name:"Child",
		//简单的声明接收
		//props:['name','age','sex']
		
		//接收的同时对数据进行类型限制
		/*props:{
			name:String,
			age:Number,
			sex:String
		}*/
		//接收的同时对数据进行类型限制+默认值的指定+必要性的限制
		props:{
			name:{
				type:String,//name的类型是字符串
				required:true,//name是必要的
			},
			age:{
				type:Number,
				default:99,//默认值
			},
			sex:{
				type:String,
				required:true
			}
		}
	}
</script>

2、子组件像父组件传值通过$emit

//父组件.vue
<template>
	<div>{{childData}}</div>
	<router-view @pushData="getChildData"></router-view>
</template>
<script>
	export default{
		data(){
			return{
				ChildData:"",//定义获取子组件的数据
			}
		},
		methods:{
			getChildData(data){
				this.ChildData=data//想要获取子组件的数据,并赋值给自己的childData
			}
		}
	}
</script>
//子组件.vue
<template>
	<div @click="sendData">点我将数据传递给父组件</div>
</template>
<script>
	export default{
		data(){
			return {
				data:"我是来自子组件的数据"
			}
		},
		medthods:{
			sendData(){
				this.$emit('pushData',this.data)
			}
		}
	}
</script>
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值