Vue props实现父组件给子组件传递数据

本文详细介绍了如何在Vue中使用Props进行数据传递,包括直接接收、类型限制和配置选项。同时提到Props的不可变性,以及如何通过data属性进行数据修改的策略。

Vue中的配置项Props能让组件接收外部传递过来的数据。

一、传递数据

在要传递的组件标签中配置传递信息:

属性名 = "属性值"

 

注意:如果传递的属性值是一个表达式,要使用:属性名="属性值" 的形式。

二、接收数据

在目标组件中配置props进行数据接收:

方式一:直接接收

注意:这里的属性名和上面传递数据时配置的属性名要相同

props:["属性1", "属性2"]

 

方式二:限制类型

可以通过限制类型的方式限制传递过来的数据类型,放置数据出错:

props:{  属性1:类型,  属性2:类型  }

 

方式三:所有配置项

完整写法中我们可以对每一个接收的属性再进行单独的配置:

props:{  属性1:{ // 配置项 },  属性2: { // 配置项 }  }

 有如下配置项:

type    // 属性的数据类型

required    // 该属性是否为必填项

default    // 若未传该属性,设置默认值

 

三、注意事项

 Vue规定我们通过props接收过来的属性不能够修改。

如果我修改,就会进行控制台报错:

那我们如果真的想要对接收过来的数据进行修改该怎么办呢?

我们可以配置两份数据,一份是props接收过来的数据,一份是组件中data的数据,data中的数据用于修改。

因为props的优先级比data高,所以我们能在data中收到props中的数据:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值