处理来自ElasticSearch的对象-我需要重建它吗?

时间:2019-03-28 13:46:07

标签: javascript reactjs object elasticsearch

因此,我正在使用一个名为Reactive的库,该库与Elastic Search一起使用以显示结果并设置查询。我正在使用ReactiveComponent创建我自己的自定义下拉列表,并且当我使用带有自定义标签的范围时。.意思是,设置`Keyed:true`,(Reference, take a look at Keyed Response and the response object)我不再得到数组,而是我得到一个物体,很难显示我想要的项目。

所以我得到的响应如下:

{
  2000 - 2005: { from: 2000, to: 2005, doc_count: 32 }
  2006 - 2010: { from: 2006, to: 2010, doc_count: 77 }
  2011 - 2015: { from: 2011, to: 2015, doc_count: 94 }
  2016 - 2018: { from: 2016, to: 2018, doc_count: 28 }
}

但是为了映射并显示必要的值,我希望它看起来更像

[{ key: "2016-2018", from: 2016, to: 2018, doc_count: 28} ] (etc)...

关于我应该怎么做的任何建议?重建对象还是朝另一个方向前进?

2 个答案:

答案 0 :(得分:1)

仅在请求中未指定keyed: true的情况下,基于您提供的ElasticSearch链接不会得到所需的内容吗?

好吧,否则请使用Object.entries

Object.entries(response).map(([key, value]) => {
  console.log(key) // "2016-2018"
  console.log(value) // { from: 2016, to: 2018, doc_count: 28 }
})

答案 1 :(得分:0)

这对我有用:

const reconstructedResults = [];
      const results = aggregations[searchType].buckets;
      Object.keys(results).map(datum => {
        const datapoint = { key: datum, ...results[datum] };
        results[datum] = datapoint;
        return reconstructedResults.push(results[datum]);
      });