使用JavaScript对象fom解析具有可变根元素的JSON

时间:2018-10-15 19:38:36

标签: javascript jquery json

我正在尝试编写JavaScript以使用已解析的JSON,但是JSONP具有变量根,如下所示:

hs

使用jquery解析后,我可以引用JavaScript对象,例如: {"AAPL":{"quote":{"symbol":"AAPL","change":-3.34}}, "FB":{"quote":{"symbol":"FB","change":1.03}}, "TSLA":{"quote":{"symbol":"TSLA","change":2.9}}} var stocks = ['AAPL', 'FB', 'TSLA']; var stocksUrl = stocks.join(','); var url = 'https://api.iextrading.com/1.0/stock/market/batch?symbols=' + stocksUrl + '&types=quote'; $.getJSON(url, function(data) {

但是,由于对象的长度是可变的,而根元素是可变的,所以我不确定如何使用for循环遍历符号和更改元素。

我的问题是如何删除可变的根元素并保留子元素,以便引用对象后缀,以使引号成为根元素,即:

console.log(JSON.stringify(data.AAPL.quote.symbol));
}

我尝试过Remove outer Object from certain key but keep inner objects,但是该解决方案是针对已知元素名称的。我可以对变量对象名称执行类似的操作吗?还是有更好的方法来解决问题?

谢谢。

3 个答案:

答案 0 :(得分:0)

Object.values();是一种可以为您提供仅包含对象值的数组的方法。

所以这个对象

{
    "fb": {
        "a": 1,
        "b": 2,
        "c": 3
    },
    "google": {
        "a": 1,
        "b": 2,
        "c": 3
    },
    "ig": {
        "a": 1,
        "b": 2,
        "c": 3
    }
}

可以变成这样:

var stuff_array = Object.values(stuff);
// turns into this
stuff_array = [
    {
        "a": 1,
        "b": 2,
        "c": 3
    },
    {
        "a": 1,
        "b": 2,
        "c": 3
    },
    {
        "a": 1,
        "b": 2,
        "c": 3
    }
]

因此,现在您有了一个数组,可以使用大约10种不同的循环方法(.forEach,.map,.reduce,for循环和while循环)中的任何一种来对其进行循环。

答案 1 :(得分:0)

您可以尝试类似的方法,在这种情况下,您无需使用核心密钥名称

var data = {"AAPL":{"quote":{"symbol":"AAPL","change":-3.34}},
             "FB":{"quote":{"symbol":"FB","change":1.03}},
         "TSLA":{"quote":{"symbol":"TSLA","change":2.9}}};

var keysArr= Object.keys(data);
for(var i=0;i<keysArr.length;i++){
    console.log(data[keysArr[i]].quote.symbol)
}

答案 2 :(得分:0)

您可以修改the example you provided为您工作。

function removeJSONString(obj) {
  let keys = Object.keys(obj);

    keys.map(key => {
      Object.assign(obj[key], obj[key].quote);
      delete obj[key].quote;
    });

  return obj;
}

这里是一个jsfiddle,您可以随便玩以获得您的期望。