01 React快速入门(一)——使用循环时对于‘key’报错处理

问题描述:

      在刚开始接触react学习的时候,编写一个小功能时,使用了map来循环一个数组中的数据,输出到前端页面,代码调试运行后正常显示,但是打开控制台却发现有一条关于“key”的报错消息,详细信息如下:

      上网查阅资料得知,此错误出现是因为与react中的diff算法有关系;

      简单的理解就是:react中循环输出时要有一个key,并且这个key不能重复

 

解决方法:

      1 定义一个变量,赋值为0,然后定义key,让其值从0开始增加,如下所示:

constructor(props){ //组件初始化函数,一调用组件就自动执行
super(props); //初始化一些参数,不必理会
this.state={ //定义state来存放数据
list:[
'learn react',
'learn english'
],
reactid:0 //此参数主要是解决key的报错问题而定义
}
}


<ul>
{
this.state.list.map((item)=>{
return <li key={'li_'+this.state.reactid++}>{item}</li>;
})
}
</ul>

      解决之后打开控制台发现,只有一条警告信息,之前的错误消息已经没有了:

 

      2 如果从数组中通过map获取值,我们除了能获取到值之外还能获取到它的索引,所以我们可以用获取到的索引来对他进行key的定义,如下:

<ul>
{
this.state.list.map((item,index)=>{
return <li key={index}>{item}</li>;
})
}
</ul>

posted @ 2018-09-29 13:47  X北辰北  阅读(397)  评论(0编辑  收藏  举报