[英]how to access nested object in react
我无法访问反应组件中的价格。 我尝试使用能够访问图像和id等对象的地图,但是当尝试访问价格时它不起作用。 我收到以下错误
Map 不是
{groups.map((user, index) => (user.price.map(i=><p>i.regular</p>)
JSON
[
{
"id": "shop/new/all-new",
"name": "All New",
"categoryType": "subcat",
"groups": [
{
"id": "modern-leaning-narrow-bathroom-shelf-h5074",
"name": "Modern Leaning Narrow Bathroom Shelf",
"links": {
"www": "https://www.westelm.com/products/modern-leaning-narrow-bathroom-shelf-h5074/"
},
"price": { "regular": 149, "selling": 111.75, "type": "special" },
"thumbnail": {
"size": "m",
"meta": "",
"alt": "",
"rel": "thumbnail",
"width": 363,
"href": "https://www.westelm.com/weimgs/ab/images/wcm/products/201952/0001/modern-leaning-narrow-bathroom-shelf-m.jpg",
"height": 363
},
"hero": {
},
"images": [
{ },
{
},
{
}
],
"swatches": [],
"messages": [],
"flags": [
],
"reviews": {
}
},
[..more objects]
groups.user.price
是一个对象,而不是一个数组,所以map
不是它的函数。 相反,您可能想要做类似的事情
const thing = { "id": "shop/new/all-new", "name": "All New", "categoryType": "subcat", "groups": [{ "id": "modern-leaning-narrow-bathroom-shelf-h5074", "name": "Modern Leaning Narrow Bathroom Shelf", "links": { "www": "https://www.westelm.com/products/modern-leaning-narrow-bathroom-shelf-h5074/" }, "price": { "regular": 149, "selling": 111.75, "type": "special" }, }]}; thing.groups.map(group => Object.keys(group.price).map(priceOpt => console.log(priceOpt, group.price[priceOpt])));
Object.keys()
将接受一个对象并为您提供所有键的数组,然后您可以调用map
。
您不能在对象上使用地图。
尝试这个
{groups.map((user, index) => {
return (<div>
{Object.keys(user.price).map(i=><p>user.price[i]</p>}
</div>);
}}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.