如何在Json Array中获取值并分别使用它们

时间:2017-12-14 09:29:07

标签: javascript jquery json

我有一个JSON,我希望将数组部分中的每个字段分开,然后我想分别使用每个字段并将它们放在单独的数组中。

例如我在我的数组中有两个部分,我想将第一部分分为第1部分和第2部分。

我必须将Json发送到我的第二页,格式为room1和room 2.我不知道怎么能这样做

我的json现在就是这样:

"rooms": [
    {
      "adultcount": "1",
      "childcount": "1,1"
    },
    {
      "adultcount": "1",
      "childcountandage": "0 "
    }
]

但我想改变它:

"rooms": [
    {
        "rooms1": {
            "adultcount": "1",
            "childcount": "1,1"
        }
    },
    {
        "rooms2": {
            "adultcount": "2",
            "childcount": "10,1"
        }
    }
]

然后我需要使用它们。 我怎么能用jquery做到这一点?

没有必要更改json代码我只是编写了新的json示例以更好地定义。

这是我的代码:

$( document ).ready(function() {
var research={"rooms":[{ "adultcount":"1","childcount":"1,1" },{ "adultcount":"1","childcountandage":"0 " }] }
var adultcount = research.rooms[0].adultcount;
var childcount = research.rooms[0].childcount;

});

3 个答案:

答案 0 :(得分:4)

由于您有一个要在对象中创建的数组,并且属性名称似乎是数组中的索引,因此您可以使用基本的array.reduce:

var rooms = [
    { "adultcount":"1", "childcount":"1,1" },
    { "adultcount":"2", "childcount":"10,1" }
];

var roomsMap = rooms.reduce( function( map, room, index ) {
    map[ 'room' + ( index + 1 ) ] = room;
    return map;
}, {} );

var otherRoomsMap = rooms.map( function( room, index ) {
    var wrapper = {};
    wrapper[ 'room' + ( index + 1 ) ] = room;
    return wrapper;
} );

console.log( roomsMap );

console.log( otherRoomsMap );

编辑:

我添加了保持数组的另一个例子,只是包装对象是另一个对象,但我不知道它会给原始数组带来什么好处。

答案 1 :(得分:0)

您可以使用循环

访问您的json数组
$.each(research, function (key, value) {
    var adultcount = value.adultcount;
    var childcount = value.childcount;
    console.log("Adult count is:"+value.adultcount);
    console.log("Child count is:"+value.childcount);
});

答案 2 :(得分:0)

试试这个:

var research={"rooms":[{ "adultcount":"1","childcount":"1,1" },{"adultcount":"1","childcountandage":"0 " }] };

var newResearch = {"rooms": []};

research.rooms.forEach(function(r) {
    newResearch.rooms.push({"room1": r[0], "room2": r[1]});
});

console.log(newResearch);