我有以下代码可行。但是,有很多重复。这是代码。
<tr>
<th>Brand</th>
<td>{ a_data.brand }</td>
<td>{ b_data.brand }</td>
<td>{ c_data.brand }</td>
</tr>
<tr>
<th>Model</th>
<td>{ a_data.model }</td>
<td>{ b_data.model }</td>
<td>{ c_data.model }</td>
</tr>
<tr>
<th>Variant</th>
<td>{ a_data.variant }</td>
<td>{ b_data.variant }</td>
<td>{ c_data.variant }</td>
</tr>
我尝试创建一个数组const data = ['a_data', 'b_data', 'c_data'];
并循环遍历该数组,以forEach
以及map
动态显示变量。但它没有显示任何内容。
如何将其置于循环中?
答案 0 :(得分:4)
您的问题有很多解决方案,一个简单的解决方案就是
const a_data = {
brand:'a',
model:'aModel',
variant:'aVariant'
}
const b_data = {
brand:'b',
model:'bModel',
variant:'bVariant'
}
const c_data = {
brand:'c',
model:'cModel',
variant:'cVariant'
}
const data = [a_data,b_data,c_data];
const brands = data.map(brand => (
<td>{ brand.brand }</td>
));
const models = data.map(brand => (
<td>{ brand.model }</td>
));
const variants = data.map(brand => (
<td>{ brand.variant }</td>
));
<tr>
<th>Brand</th>
{ brands }
</tr>
<tr>
<th>Model</th>
{ models }
</tr>
<tr>
<th>Variant</th>
{ variants }
</tr>
正如您在此解决方案中所看到的,我使用模拟对象并将此对象添加到名为data的数组中。
答案 1 :(得分:1)
这可能有点冗长,但如果你愿意,你可以重构它。要点是:
const data = [a_data, b_data, c_data];
const brands = data.map(brand => <td>{ brand.brand }</td>);
const models = data.map(brand => <td>{ brand.model }</td>);
const variants = data.map(brand => <td>{ brand.variant }</td>);
<tr>
<th>Brand</th>
{ brands }
</tr>
<tr>
<th>Model</th>
{ models }
</tr>
<tr>
<th>Variant</th>
{ variants }
</tr>