【记录】react警告:Warning: Encountered two children with the same key解决办法

问题:

在做前端项目时使用react+ant design使用<Select>标签出现警告如下:

Warning: Encountered two children with the same key, `.$高峰出车率`. Keys should be unique so that components maintain their identity across updates. Non-unique keys may cause children to be duplicated and/or omitted — the behavior is unsupported and could change in a future version.

程序能够正常运行,但是测试时会出现多余option,

 

 时常会添加相同option(明显:高峰出车率(%)是多余的);在每次出现的多余的option时,都会有上面的警告出现。

原因:

是由于option中有重复的选项,当每次刷新时由于重复的选项没有删除,会保留(这是react的锅,嗯。。。我是这么认为的)。

解决:

只要去掉重复的选项即可。解决es6对象数组,根据某个对象的属性去重方法如下:

let res = new Map();//CONTRASTNAME为对象的属性
let arr_file=payload.data.filter((item)=>!res.has(item.CONTRASTNAME) && res.set(item.CONTRASTNAME, 1))//过滤重复的数据

总结:这个问题应该是可以避免的 ,数据在后台应该需要控制,而不是在前端控制。

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值