Ich versuche, über eine Immutable.js-Map zu iterieren, um eine Komponente zu rendern, aber obwohl dies gerendert wird, wird auch der Schlüssel für die Seite gerendert. Ich bin mir nicht sicher warum.Reagieren 16 Iterieren über Map-Rendering-Schlüssel
render() {
const myMap = new Map({foo: '', bar: 'http://google.com/'})
const {showFoo, titleAndUrl} = this.props
return (
<ul style={[
styles.container,
showFoo && styles.container.inline,
]}>
{myMap.map((title, url) => this.renderTab(url, title))}
</ul>
)
}
renderTab(title, url) {
const {showFoo, isFoo} = this.props
return (
<li key="sb" style={[
styles.listItem,
showFoo && styles.listItem.inline,
]}>
<a
href={url}
key={title}
style={[
styles.link,
styles.activeLink,
showFoo && styles.link.inline,
]}
className={isFoo ? "style" : ''}>
{title}
</a>
</li>
)
}
}
Die beiden Namen und URLs korrekt gerendert werden jedoch Nachschlüssel gemacht dh foo wird zweimal gemacht und so ist eine Bar, aber eine der foo und bar Tasten hat keine Stile, was darauf hindeutet, wird es außerhalb gerendert wird von this.renderTab
Rendered HTML:
<ul data-radium="true"
style="display: flex; align-items: center; padding: 0px; margin: 0px; list-style: none; width: 100%; border-top: 1px solid rgb(221, 221, 221); height: 48px;">
foo
<li data-radium="true" style="display: flex; width: 50%; height: 47px; cursor: default;"><a href=""
class=""
data-radium="true"
style="display: flex; justify-content: center; align-items: center; width: 100%; text-decoration: none; font-weight: 500; font-size: 16px; color: rgb(0, 31, 91); transition: color 0.1s linear;">foo</a>
</li>
bar
<li data-radium="true" style="display: flex; width: 50%; height: 47px; cursor: default;"><a
href="http://google.com" class="" data-radium="true"
style="display: flex; justify-content: center; align-items: center; width: 100%; text-decoration: none; font-weight: 500; font-size: 16px; color: rgb(0, 31, 91); transition: color 0.1s linear;">bar</a>
</li>
</ul>
'Karte()' eine Liste zurückgibt, tut es nicht nur eine Schleife über Elemente. Dies könnte aus irgendeinem Grund verwandt sein. Aber ich bin nicht sicher, warum es den Schlüssel nicht die ganze Komponente zurückgeben würde. – Y2H