React 中两个具有相同键的孩子

新手上路,请多包涵

应用程序有效,我的课程确实添加了一个新元素,但我在控制台中看到以下警告!

警告:遇到两个具有相同密钥的孩子 [object Object] 。密钥应该是唯一的,以便组件在更新时保持其身份。非唯一键可能会导致子项被复制和/或省略——这种行为不受支持,并且可能在未来的版本中发生变化。在 div 中(由 ContentBody 创建) 在 ContentBody 中

这是我的渲染部分:

  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,
      },
    );

  }

有什么建议么?

更新:这是我的入门项目的链接: https ://github.com/zlatnaspirala/react-vs-typescript-starter

原文由 Nikola Lukic 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 995
2 个回答

您可以在 map 函数中传递另一个参数,如下所示:

 this.state.elements.map((element, index) => {
   return <span style={element.myStyle} key={index} >{element}</span>;
});

Array.prototype.map 函数的第二个参数实际上包含该数组中特定元素的当前索引。

这样,您将确保您的密钥不会重复。

原文由 heyitsmarcucu 发布,翻译遵循 CC BY-SA 4.0 许可协议

请参阅此以更多地了解“关键”相关警告和最佳实践

 function ListItem(props) {
  // Correct! There is no need to specify the key here:
  return <li>{props.value}</li>;
}

function NumberList(props) {
  const numbers = props.numbers;
  const listItems = numbers.map((number) =>
    // Correct! Key should be specified inside the array.
    <ListItem key={number.toString()}
              value={number} />

  );
  return (
    <ul>
      {listItems}
    </ul>
  );
}

const numbers = [1, 2, 3, 4, 5];
ReactDOM.render(
  <NumberList numbers={numbers} />,
  document.getElementById('root')
);

访问此链接 https://reactjs.org/docs/lists-and-keys.html#extracting-components-with-keys 了解更多信息

原文由 user10298214 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进