如何在javascript中解析嵌套JSON中的元素?

时间:2017-11-09 16:37:02

标签: javascript jquery json xmlhttprequest jsonparser

我将以下json作为responseText返回后,我将一个GET请求发送到rest api:

{
    "ehrs": [
        {
            "uid": "11111111-1111-1111-1111-111111111111",
            "dateCreated": "2017-09-21 04:36:47",
            "subjectUid": "11111111-1111-1111-1111-111111111111",
            "systemId": "CABOLABS_EHR_SERVER",
            "organizationUid": "123456"
        },
        {
            "uid": "22222222-1111-1111-1111-111111111111",
            "dateCreated": "2017-09-21 04:36:47",
            "subjectUid": "22222222-1111-1111-1111-111111111111",
            "systemId": "CABOLABS_EHR_SERVER",
            "organizationUid": "123456"
        },
        {
            "uid": "33333333-1111-1111-1111-111111111111",
            "dateCreated": "2017-09-21 04:36:48",
            "subjectUid": "33333333-1111-1111-1111-111111111111",
            "systemId": "CABOLABS_EHR_SERVER",
            "organizationUid": "123456"
        },
        {
            "uid": "44444444-1111-1111-1111-111111111111",
            "dateCreated": "2017-09-21 04:36:48",
            "subjectUid": "44444444-1111-1111-1111-111111111111",
            "systemId": "CABOLABS_EHR_SERVER",
            "organizationUid": "123456"
        },
        {
            "uid": "55555555-1111-1111-1111-111111111111",
            "dateCreated": "2017-09-21 04:36:48",
            "subjectUid": "55555555-1111-1111-1111-111111111111",
            "systemId": "CABOLABS_EHR_SERVER",
            "organizationUid": "123456"
        },
        {
            "uid": "97fecfa9-d51c-440f-93eb-cb8bbabc5cdc",
            "dateCreated": "2017-09-27 22:53:55",
            "subjectUid": "ef70c3bf-8aba-4f4b-83b7-097f2aff60f6",
            "systemId": "CABOLABS_EHR_SERVER",
            "organizationUid": "123456"
        },
        {
            "uid": "4e363a7c-0b25-405c-93d8-1361f4775ccd",
            "dateCreated": "2017-10-10 06:08:58",
            "subjectUid": "228084fb-10d8-4441-8683-aad526e2c5fd",
            "systemId": "CABOLABS_EHR_SERVER",
            "organizationUid": "123456"
        },
        {
            "uid": "3c6b8a98-1488-427b-8251-5bebad35afda",
            "dateCreated": "2017-10-10 21:03:44",
            "subjectUid": "3dd3a7b1-b642-4e9b-b12a-4fcd10af6e4f",
            "systemId": "CABOLABS_EHR_SERVER",
            "organizationUid": "123456"
        }
    ],
    "pagination": {
        "max": 10,
        "offset": 0,
        "nextOffset": 10,
        "prevOffset": 0
    },
    "timing": "0 ms"
}

我想从此json的所有“ehrs”元素中仅获取“uid”和“dateCreated”元素,然后以适当的方式显示它们,同时显示属性名称及其值。我尝试了以下代码:

var ehrjson = (this.responseText);
var ehrobj = JSON.parse(ehrjson);
document.getElementById("ehrlist").innerHTML = ehrobj.ehrs.uid+"    ----     "+ehrobj.ehrs.dateCreated+"\n";

但它在html中显示[undefined] ---- [undefined]作为输出。 我也有一种感觉,我的代码错了,但无法想象该做什么。如何解决这个问题?

3 个答案:

答案 0 :(得分:1)

ehrobj = JSON.parse(ehrjson)之后,您获得了一个具有ehrs属性的对象,该对象是一个数组

您只能访问数组中各个元素的属性uiddateCreated

所以你要么(1)可以显示单个元素属性uiddateCreated

ehrobj.ehrs[0].uid+" "+ehrobj.ehrs[0].dateCreated

或(2)你可以将它们全部连接起来

ehrobj.ehrs.map(e => e.uid + " " + e.dateCreated).join("\n")

答案 1 :(得分:1)

你的json解析不是问题。您必须访问ehrobj.ehrs的每个数组元素并像在此片段中一样循环它们



// ehrobj as js-object to get this snippet running
var ehrobj = {
		"ehrs": [
			{
				"uid": "11111111-1111-1111-1111-111111111111",
				"dateCreated": "2017-09-21 04:36:47",
				"subjectUid": "11111111-1111-1111-1111-111111111111",
				"systemId": "CABOLABS_EHR_SERVER",
				"organizationUid": "123456"
			},
			{
				"uid": "22222222-1111-1111-1111-111111111111",
				"dateCreated": "2017-09-21 04:36:47",
				"subjectUid": "22222222-1111-1111-1111-111111111111",
				"systemId": "CABOLABS_EHR_SERVER",
				"organizationUid": "123456"
			},
			{
				"uid": "33333333-1111-1111-1111-111111111111",
				"dateCreated": "2017-09-21 04:36:48",
				"subjectUid": "33333333-1111-1111-1111-111111111111",
				"systemId": "CABOLABS_EHR_SERVER",
				"organizationUid": "123456"
			},
			{
				"uid": "44444444-1111-1111-1111-111111111111",
				"dateCreated": "2017-09-21 04:36:48",
				"subjectUid": "44444444-1111-1111-1111-111111111111",
				"systemId": "CABOLABS_EHR_SERVER",
				"organizationUid": "123456"
			},
			{
				"uid": "55555555-1111-1111-1111-111111111111",
				"dateCreated": "2017-09-21 04:36:48",
				"subjectUid": "55555555-1111-1111-1111-111111111111",
				"systemId": "CABOLABS_EHR_SERVER",
				"organizationUid": "123456"
			},
			{
				"uid": "97fecfa9-d51c-440f-93eb-cb8bbabc5cdc",
				"dateCreated": "2017-09-27 22:53:55",
				"subjectUid": "ef70c3bf-8aba-4f4b-83b7-097f2aff60f6",
				"systemId": "CABOLABS_EHR_SERVER",
				"organizationUid": "123456"
			},
			{
				"uid": "4e363a7c-0b25-405c-93d8-1361f4775ccd",
				"dateCreated": "2017-10-10 06:08:58",
				"subjectUid": "228084fb-10d8-4441-8683-aad526e2c5fd",
				"systemId": "CABOLABS_EHR_SERVER",
				"organizationUid": "123456"
			},
			{
				"uid": "3c6b8a98-1488-427b-8251-5bebad35afda",
				"dateCreated": "2017-10-10 21:03:44",
				"subjectUid": "3dd3a7b1-b642-4e9b-b12a-4fcd10af6e4f",
				"systemId": "CABOLABS_EHR_SERVER",
				"organizationUid": "123456"
			}
		],
		"pagination": {
			"max": 10,
			"offset": 0,
			"nextOffset": 10,
			"prevOffset": 0
		},
		"timing": "0 ms"
	};


	ehrobj.ehrs.forEach(function (ehr) {
		document.getElementById("ehrlist").innerHTML += ehr.uid + "    ----     " + ehr.dateCreated + "\n";
	});

<pre id="ehrlist"></pre>
&#13;
&#13;
&#13;

答案 2 :(得分:0)

请注意,ehrobj.ehrs是一个数组,因此ehrobj.ehrs.uid不是他的属性。

    ehrobj.ehrs === [
    {
        "uid": "11111111-1111-1111-1111-111111111111",
        "dateCreated": "2017-09-21 04:36:47",
        "subjectUid": "11111111-1111-1111-1111-111111111111",
        "systemId": "CABOLABS_EHR_SERVER",
        "organizationUid": "123456"
    }, ... ]

你需要迭代ehrs数组。

let ehrlist = document.getElementById( 'ehrlist' );
ehrobj.ehrs.forEach( function(ehr){
   let newEl = document.createElement('div');
   newEl.innerHTML = ehr.uid + ' ------ ' + ehr.dateCreated;
   ehrlist.appendChild( newEl );
} )