Add Keys with Examples (#32942)

* Add Keys with Examples

* fix: added front matter block
pull/35143/head
KurtWayn3 2019-02-10 20:32:24 -07:00 committed by Randell Dawson
parent 4d2c268cd6
commit 95e541882c
1 changed files with 29 additions and 0 deletions

View File

@ -0,0 +1,29 @@
---
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)