这个问题在这里已有答案:
应用程序工作,我的类真的添加了一个新元素,但我在控制台中看到下面的警告!
警告:遇到两个具有相同键的子项,[object Object] . 密钥应该是唯一的,以便组件在更新时保持其身份 . 非唯一键可能导致子项被复制和/或省略 - 行为不受支持,并且可能在将来的版本中更改 . 在ContentBody中的div(由ContentBody创建)中
Here is my render part :
return (
<div ref={this.myRef} style={this.state.myHomeStyle} >
{this.state.elements.map((i: any) => {
console.log(">>i>>>>", i);
return <span style={i.myStyle} key={i} >{i}</span>;
})}
</div>
);
// Where i init
public componentDidMount() {
console.log('componentDidMount');
this.myDOM = this.myRef.current;
this.myDOM.addEventListener(myEventsList.adaptCss, this.adaptCss);
this.add(12,this.INLINE_TEST_ELE, null);
this.add(13,this.INLINE_TEST_ELE, null);
}
// Function add
private add = (id: number, content: any, event: any ) => {
let localArr: any[] = [];
let mEvent: any = null;
if (event !== undefined) {
mEvent = event;
}
localArr = this.state.elements;
localArr.push(React.createElement("div", { key: id , onClick : mEvent }, content));
this.setState(
{
elements: localArr,
visibility : true,
},
);
}
有什么建议?
3 回答
您可以在 Map 函数中传递另一个参数,如下所示:
Array.prototype.map
函数的第二个参数实际上包含该数组中特定元素的当前索引 .这样,您就可以确保您的密钥不会重复 .
有关“关键”相关警告和最佳实践的更多理解,请参阅此处
有关更多信息,请访问此链接https://reactjs.org/docs/lists-and-keys.html#extracting-components-with-keys
你传递的元素不是索引 . 如果你的元素相同,那么就会抛出错误 . 要传递索引,请使用第二个参数:
现在,使用
index
将为您提供不同的密钥 .