[Vue warn]: Invalid prop: type check failed for prop “value“. Expected String with value “1“ 解决办法

Vue错误提示:

[Vue warn]: Invalid prop: type check failed for prop "value". Expected String with value "1", got Number with value 1.

提示的问题:是数据不匹配, 传数的是Number类型 ,而组件需要的是String类型

在这里,需要对数据类型进行强制转换即可,用String()强转。

 

我实际遇到的问题是:

开发uni-app时,使用checkbox-group多选组件,组件的items数据如下:

items: [{ value: 'USA', name: '美国' }, { value: 'CHN', name: '中国', checked: 'true' }, { value: 'BRA', name: '巴西' }, { value: 'JPN', name: '日本' }, { value: 'ENG', name: '英国' }, { value: 'FRA', name: '法国' } ]

然后接口获取到的数据,是数组形式,一般id值在数据库里都是int类型,相当于是Number类型 。
这里想用id作为  items 里的value值,就会报错,要进行强转。
 

this.category        = res.data.data;
for (var i = 0, lenI = this.category.length; i < lenI; ++i) {  
  this.category[i].category_id = String(this.category[i].category_id)  
} 

然后在checkbox-group组件 绑定数据就行了

<label class="uni-list-cell uni-list-cell-pd wd300" v-for="item in category" :key="item.category_id"> 
  <view>
    <checkbox :value="item.category_id" :checked="item.checked" />
  </view> 
  <view>{{item.category_name}}</view>
</label>

 

 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值