我试图在函数内部调用对象文字元素,但它不起作用...当它陷入在函数内部调用元素“ image”时,它给了我一个未定义的错误。

var w1 = {warframeName:"Ash", health:450, shield:300, power:150, armor:65.0, sprint:1.15, stamina:100, image:"images/warframes/ash.jpg"};

$(".woption").click(function() {
    var wClass = $(this).attr('class').split(' ')[0];

    for(var x = 1; x <23; x++) {
        if(wClass == "w"+x) {
            $(".warframe_selector").css("background", "url(" + ('w'+x).image +") no-repeat", "important");
            $(".warframe_selector").css( "background-size", "100%" );
        } else {}
    }

    $("#cover").fadeOut(function() {});
    $(".warframe_option").fadeOut(function() {});
});

最佳答案

在您的代码中,w1不是一个数组,它是一个指向对象文字的变量。这意味着您无法像('w' + 1).image那样访问它。您有2个选择


使其成为数组,像数组一样访问它

var w = [{warframeName:"Ash", health:450, shield:300, power:150, armor:65.0, sprint:1.15, stamina:100, image:"images/warframes/ash.jpg"}];
... w[x].image  ...

使对象文字具有一定范围,并使用方括号表示法访问它

 window.myNamespace = {};
 window.myNamespace.w1 = {warframeName:"Ash", health:450, shield:300, power:150, armor:65.0, sprint:1.15, stamina:100, image:"images/warframes/ash.jpg"}
... window.myNamespace['w' + x].image ...

08-08 07:34