javascript - 根据索引名称动态解析 JSON 数据
问题描述
如何根据索引名称解析此对象数据。我与您分享一个数据示例。但在实际项目中,我也获得了大量的索引和子 json 数据。
下面的 JSON 数据示例:
var vehicles = {
'cars':[
{
"name":"Car 1",
"model":"Car 1 Model 1"
},
{
"name":"Car 2",
"model":"Car 2 Model 2"
},
],
'bikes':[
{
"name":"Bike 1",
"model":"Bike Model 1",
},
{
"name":"Bike 2",
"model":"Bike Model 2",
}
],
'buses':[
{
"name":"Bus 1",
"model":"Bus Model 1",
},
{
"name":"Bus 2",
"model":"Bus Model 2",
}
],
}
我从服务器动态获取这个。在这个 json 数据包中,汽车/自行车/公共汽车。但也可以是不同的名称。
问题是如何根据汽车/自行车访问汽车 1 或自行车 1,而无需像下面这样定义
console.log(vehicles.buses[0].name);
Output : Bus 1
如果您看到此处定义的总线。我想动态地做到这一点。怎么做?
解决方案
如果我理解了您的问题,您希望能够在运行前不知道属性名称的情况下访问属性中的每个数组。
因此,您可以使用Object.keys()
集合和括号表示法来访问数组,如下所示:
Object.keys(vehicles).forEach((key) => {
console.log(vehicles[key][0].name);
});
var vehicles = {
'cars': [{
"name": "Car 1",
"model": "Car 1 Model 1"
}, {
"name": "Car 2",
"model": "Car 2 Model 2"
}],
'bikes': [{
"name": "Bike 1",
"model": "Bike Model 1",
}, {
"name": "Bike 2",
"model": "Bike Model 2"
}],
'buses': [{
"name": "Bus 1",
"model": "Bus Model 1"
}, {
"name": "Bus 2",
"model": "Bus Model 2"
}],
'foo': [{
"name": "Foo 1",
"model": "Foo Model 1"
}, {
"name": "Foo 2",
"model": "Foo Model 2"
}]
}
Object.keys(vehicles).forEach((key) => {
console.log(vehicles[key][0].name);
});
推荐阅读
- python - 在 Python 中合并两个排序的链表
- c# - 无法从 Expression< Func< Entity, bool> > 转换为 Func< Entity, bool>
- node.js - 从 MongoDB 的值创建新日期?
- java - 读入数组并显示数组
- php - Xdebug 的彩色 var_dump 无法正常工作
- azure-devops - 是否可以在基本计划中包含 Azure DevOps 项目?
- python - Scrapy:简单项目
- python - 将 3D .mat 文件加载为灰度 numpy 数组
- angular - 如何根据角度 4 中的其他第一个下拉值更改第二个下拉值
- android - Android Studio ---- 路径不可写。请选择一个新位置