Javascript带变量的对象表示法

FFi*_*ish 3 javascript object notation

我的PHP脚本specs.php输出以下内容:

{
    "hd": {
        "dimensions": [
            "1920x1080",
            "1920x1080",
            "1920x1080" 
        ],
        "sizes": [
            "603 KB",
            "265 KB",
            "438 KB" 
        ] 
    },
    "medium": {
        "dimensions": [
            "800x530",
            "800x530",
            "800x530" 
        ],
        "sizes": [
            "198 KB",
            "105 KB",
            "152 KB" 
        ] 
    },
    "status": "success"
}
Run Code Online (Sandbox Code Playgroud)

使用jQuery我加载JSON并将其分配给specs_obj
我可以使用specs_obj 访问第一个项目的"medium""sizes".medium.sizes [0]
如何在点表示法中使用变量?

var specs_obj;
$.post("specs.php", {},
    function(data) {
        if (data.status == "success") {
                specs_obj = data;
                writeSizes("medium");
        } else {}
    }, "json"
);

function writeSizes(preset) {
    // test get medium dimensions from first file
    var size = specs_obj. medium.sizes[0];
    // var size = specs_obj.preset.sizes[0];
}
Run Code Online (Sandbox Code Playgroud)

T.J*_*der 8

您不能在点表示法中使用变量,但可以使用括号表示法:

var size = specs_obj[preset].sizes[0];
Run Code Online (Sandbox Code Playgroud)

如果preset包含字符串"medium",那在功能上与:

var size = specs_obj.medium.sizes[0];
Run Code Online (Sandbox Code Playgroud)