将 Javascript 响应转换为 Array/Map
Convert Javascript response to Array/Map
我从 Javascript ElasticSearch 查询得到以下响应,我需要将其映射到以下结构。有没有比我目前正在做的更有效的方法来做到这一点?
谢谢
我需要映射到的结构:(其中约 700 个)
[{
"coordinates": ["48", "37"],
"name": "something",
"population": "501"
},
我返回的数据的当前结构:
[Object, Object, Object, Object, Object, Object, Object, Object, Object, Object]
0: Object
_id: "4"
_index: "locationIndex"
_score: 1
_source: Object
coordinates: Array[2]
0: -77.080597
1: 38.892899
length: 2
__proto__: Array[0]
name: "someName"
population: 57205
1: Object
...
我正在尝试但失败了:
var results= [{
"key": 'coordinates',
resp.coordiantes[0],
resp.coordinates[1],
"key": 'name',
resp.name
})
}];
假设你的数据存储在一个myData
变量中,你可以使用Array.prototype.map
方法来操作它并实现你想要的。这是一个解决方案:
result = myData.map(function(obj) {
return {
coordinates: obj._source.coordinates,
name: obj.name,
population: obj.population
}
});
就这么简单!结果将是这样的:
[
{
"coordinates": [-77.080597, 38.892899],
"name": "some name",
"population": 52701
},
{
"coordinates": [-54.930299, 30.992833],
"name": "some name 2",
"population": 84229
},
{
"coordinates": [-82.001438, -5.38131],
"name": "some name 3",
"population": 5991
} //, ...
]
看来您不太了解Javascript中的对象语法;为了让我的回答最有意义,您不妨 read up 稍微了解一下。
现在您对对象有了更多的了解,应该很清楚您想要的是这样的:
var results = [];
for (var i = 0, len = data.length; i < len; i++)
{
var resp = data[i];
results.push({
'coordinates':resp['source']['coordinates'],
'name':resp.name,
'population':resp.population
});
}
为了加分,你可以包含一个像 jQuery 这样的 JS 框架,然后使用 map
function.
我是开源项目http://www.jinqJs.com的作者。
你可以很容易地做这样的事情来做你想做的事。
var result = jinqJs().from(data5).select(function(row){
return {coordinates: [row.coordinates[0]['0'], row.coordinates[0]['1']],
name: row.name,
population: row.population
}
});
我最喜欢 Marcos 地图解决方案,但也可以快速使用 Array.from(data)
。这在过去帮助我转换响应 API 应该是数组但还不是数组的数据。
我从 Javascript ElasticSearch 查询得到以下响应,我需要将其映射到以下结构。有没有比我目前正在做的更有效的方法来做到这一点?
谢谢
我需要映射到的结构:(其中约 700 个)
[{
"coordinates": ["48", "37"],
"name": "something",
"population": "501"
},
我返回的数据的当前结构:
[Object, Object, Object, Object, Object, Object, Object, Object, Object, Object]
0: Object
_id: "4"
_index: "locationIndex"
_score: 1
_source: Object
coordinates: Array[2]
0: -77.080597
1: 38.892899
length: 2
__proto__: Array[0]
name: "someName"
population: 57205
1: Object
...
我正在尝试但失败了:
var results= [{
"key": 'coordinates',
resp.coordiantes[0],
resp.coordinates[1],
"key": 'name',
resp.name
})
}];
假设你的数据存储在一个myData
变量中,你可以使用Array.prototype.map
方法来操作它并实现你想要的。这是一个解决方案:
result = myData.map(function(obj) {
return {
coordinates: obj._source.coordinates,
name: obj.name,
population: obj.population
}
});
就这么简单!结果将是这样的:
[
{
"coordinates": [-77.080597, 38.892899],
"name": "some name",
"population": 52701
},
{
"coordinates": [-54.930299, 30.992833],
"name": "some name 2",
"population": 84229
},
{
"coordinates": [-82.001438, -5.38131],
"name": "some name 3",
"population": 5991
} //, ...
]
看来您不太了解Javascript中的对象语法;为了让我的回答最有意义,您不妨 read up 稍微了解一下。
现在您对对象有了更多的了解,应该很清楚您想要的是这样的:
var results = [];
for (var i = 0, len = data.length; i < len; i++)
{
var resp = data[i];
results.push({
'coordinates':resp['source']['coordinates'],
'name':resp.name,
'population':resp.population
});
}
为了加分,你可以包含一个像 jQuery 这样的 JS 框架,然后使用 map
function.
我是开源项目http://www.jinqJs.com的作者。 你可以很容易地做这样的事情来做你想做的事。
var result = jinqJs().from(data5).select(function(row){
return {coordinates: [row.coordinates[0]['0'], row.coordinates[0]['1']],
name: row.name,
population: row.population
}
});
我最喜欢 Marcos 地图解决方案,但也可以快速使用 Array.from(data)
。这在过去帮助我转换响应 API 应该是数组但还不是数组的数据。