使用变量键访问 JavaScript 对象中的值

IT技术 javascript language-design
2021-01-14 20:06:10

代码:

function updateDashboardData() {
    $.getJSON("includes/system/ajaxDataInterface.php", {recordcount:1}, function(data) {
        $('.stationContainer').each(function(data) {
            var bsID = $(this).attr("id");
            var bsStatus = $(this).children('.stationStatus');
            alert(data[bsID][0].time);
            bsStatus.find('.bs_maxHandsets').text(data[bsID][0].maxHandsets);
            bsStatus.find('.bs_time').text(data[bsID][0].time);
        });
    });
}

对象数据:

{
    "A5A50000": [{
        "bsid": "A5A50000",
        "chanCount": 17,
        "time": "2009-05-27 16:36:45",
        "avgInterference": 1.711765,
        "maxInterference": 4.97,
        "avgHandsets": 205.1176,
        "maxHandsets": 315,
        "avgCalls": 6.4118,
        "maxCalls": 13,
        "avgCBA": 3868.98059,
        "maxCBA": 7463,
        "sumSuccessCBA": 197318,
        "sumTimeoutHandoff": 133,
        "sumAttemptHandoff": 1028,
        "sumDeniedHandoff": 216,
        "sumConfirmHandoff": 679,
        "sumHandoffNetwork": 61873,
        "sumJoinNetwork": 96888,
        "sumLeaveNetwork": 93754,
        "sumRcvdKeepalive": 98773,
        "sumTimeoutKeepalive": 19748,
        "sumAttemptUplink": 93689,
        "sumBlockedUplink": 62453
    }]
}

问题:

alert(data.A5A50000[0].time); 正确显示“2009-05-27 16:36:45”。

alert(bsID); 正确显示“A5A50000”。

alert(data.bsID[0].time); 报告“data.bsID 未定义”。

alert(data[bsID][0].time); 报告“数据 [bsID] 未定义”。

我有点不清楚何时评估/未评估变量。也许我忽略了一些愚蠢的事情,但我无法在这里弄清楚我的问题。

2个回答

您可以通过点表示法或括号表示法访问对象属性。

var x = {'test': 'hi'};
alert(x.test); // alerts hi
alert(x['test']); // alerts hi

当你有一个动态值时,你必须使用后者:

var property = 'test';
alert(x.property); // looks for x.property, undefined if it doesn't exist
alert(x[property]); // looks for x['test'], alerts hi

所以你真正想要的是:

alert(data[bsID][0].time);

编辑

不确定你做错了什么,但这在 Firebug 的控制台上对我有用:

var data = {"A5A50000":[{"bsid":"A5A50000","chanCount":17,"time":"2009-05-27 16:36:45","avgInterference":1.711765,"maxInterference":4.97,"avgHandsets":205.1176,"maxHandsets":315,"avgCalls":6.4118,"maxCalls":13,"avgCBA":3868.98059,"maxCBA":7463,"sumSuccessCBA":197318,"sumTimeoutHandoff":133,"sumAttemptHandoff":1028,"sumDeniedHandoff":216,"sumConfirmHandoff":679,"sumHandoffNetwork":61873,"sumJoinNetwork":96888,"sumLeaveNetwork":93754,"sumRcvdKeepalive":98773,"sumTimeoutKeepalive":19748,"sumAttemptUplink":93689,"sumBlockedUplink":62453}]};
var bsID = 'A5A50000';
alert(data[bsID][0].time);
我试过你的测试代码,它对我来说也很好用。看看上面的代码,我唯一能想象到的错误是 bsID 不是预期的。测试 bsID 的类型,它报告“字符串”。进一步的测试表明从 getJSON() 返回的数据存在问题。当我尝试访问数据来自 getJSON 的 data[bsID][0] 时,它报告未定义。如果我将数据明确定义为我在原始问题中发布的对象,它就可以工作。我需要进一步处理返回的数据以查看有什么问题。
2021-03-15 20:06:10
尝试您的建议后, alert(data[bsID][0].time); 报告“数据 [bsID] 未定义”。我已经更新了我在上面测试的代码。我正在 Firebug 的控制台中对此进行测试(显然是在 FF 上)。
2021-04-09 20:06:10

在 Javascript 中,您可以使用对象或数组样式的符号来查找属性。以下是等效的:

data.A5A50000
data['A5A50000']

使用第二种语法,您可以使用变量代替对象字符串:

data[bsID][0]
data[bsID[0]] 不是他想要的。它是数据[bsID][0]
2021-03-22 20:06:10