vue 组件传参

1、父传子

在父组件中的子组件标签上绑定一个自定义属性,自定义属性后面挂载要传递的参数。

<banner :list="list"></banner>

在子组件使用props 来接受
props 可以是个对象,也可以是个数组。
当是个数组时,接收的数据没有限制
当是个对象时,接收的数据可以限制其类型,或设置一个默认的值…
我们使用的时候根使用data中的变量一样即可。
注意:父传子时,子组件不可改变传递的数据

	export default {
		props: {
			list: {					// 接收的数据名必须跟父组件中传递的自定义属性名一致
				type: Array,		// 规定数据的类型
				default: []			// 如果父组件没有传参,使用默认数据
			},
		},
	}

2、子传父

在父组件中的子组件标签上,绑定一个自定义事件。并挂载一个事件。
然后我们在子组件中使用this.$emit(‘自定义事件名’,传递的参数),我们在父组件中触发挂载的这个事件,有一个参数,就是子组件传递过来的数据。

<heads @change="change" /> <-- 子组件 -->
// 如我们自定义事件名叫 change 
// 值为我们的change事件
	export default {
		methods:{
			change(val){
				console.log(val) // val就是我们传递过来的数据
			}
		}
	}

我们在子组件使用

<button @click="btn"></button>
<script>
	export default {
		data(){
			return {
				list:"数据",		
				}
	},
		methods:{
			btn(){
				this.$emit("change",this.list);
				// 第一个参数是我们在子组件标签上绑定的自定义事件名
				// 第二个是我们要传递的数据
			}
		}
	}
</script>

3、兄弟组件传递数据

我们的兄弟组件传值可以使用vuex来解决。
首先我们初始化一个全局的$bus
直接在跟目录下的main.js 初始化 $bus 。

window.$bus=new Vue();

在发送的一方使用

 $bus.$emit("aMsg", '数据');  
 // 我们页面A发送数据

在接收的一方使用

$bus.$on("事件名",callback)
// 我们页面B接收数据
$bus.$on("aMsg", (msg) => {
     // A发送来的消息
     // 我们的msg就是A发送过来的数据
   });
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值