I have the following code snippet that works fine in the console, but it's not displaying to the screen. Any help is appreciated.
{Object.keys(flags).forEach(product => {
return (
<>
<input
type='checkbox'
className='form-checkbox'
name={product}
value={product}
onChange={this.gatherFormData}
/>
<span className='label'>{product}</span>
</>
);
})}
The product key is not displaying on the screen, even though I can see it just fine within the console.
Should it not be:
return (
<div> // needs an element wrapper
<input
type='checkbox'
className='form-checkbox'
name={product}
value={product}
onChange={this.gatherFormData}
/>
<span className='label'>{product}</span>
</div>
);
As jonrsharpe says - you also need to use map (forEach simply iterates over the values - but doesn't return anything)
{Object.keys(flags).map(product => {
Return inside .forEach does nothing either push data to an array to use it later or return from a .map method instead
Here is an example if you need to use .forEach as in your question...
{
const products = [];
Object.keys(flags).forEach(product => {
products.push (
<>
<input
type='checkbox'
className='form-checkbox'
name={product}
value={product}
onChange={this.gatherFormData}
/>
<span className='label'>{product}</span>
</>
);
})
return products;
}
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.