30 lines
1.0 KiB
Markdown
30 lines
1.0 KiB
Markdown
|
---
|
||
|
title: Keys
|
||
|
---
|
||
|
|
||
|
# Keys
|
||
|
|
||
|
Keys are the eyes and ears on your application battlefield letting React know which items have changed or were added.
|
||
|
```javascript
|
||
|
const bestCereal = ['cookie crisp','waffle crisp','fruit loops','cinnamon toast crunch','cocoa puffs'];
|
||
|
const cerealItems = bestCereal.map((cereal) =>
|
||
|
<ul key={cereal}>
|
||
|
{cereal}
|
||
|
</ul>
|
||
|
);
|
||
|
```
|
||
|
Notice that the keys selected were all unique. The `key` is required to be unique. If you are unable to provide a unique key from the list of items you are iterating over, you can use the `index`.
|
||
|
```javascript
|
||
|
const troops = ['general','major','platoon leader','cadet','cadet'];
|
||
|
const troopItems = troops.map((soldier, index) =>
|
||
|
<ul key={index}>
|
||
|
{soldier}
|
||
|
</ul>
|
||
|
);
|
||
|
```
|
||
|
Although it is not recommended to use index if the order of items change. Many in the React community use index as a last resort.
|
||
|
|
||
|
### More Information
|
||
|
- [Keys Doc](https://reactjs.org/docs/lists-and-keys.html)
|
||
|
- [Dangers of Using Index as the Key](https://medium.com/@robinpokorny/index-as-a-key-is-an-anti-pattern-e0349aece318)
|