Javascript - 如何在程序设置后更新变量?

时间:2012-11-11 19:43:06

标签: javascript jquery procedural-programming

我有一个在我的函数顶部定义的变量和一个直接在其下引用该变量的JSON对象。一个click事件,一些循环和一个匿名函数稍后我更新第一个变量的值然后引用JSON对象的属性,期望它具有新值,但是这不起作用。

我的代码看起来像这样:

var errorval = "Not set";
var rules = {
    firstRule : {
        name : 'example',
        message : 'Needs to be '+errorval+' characters long'
    }
}
$('.button').on('click', function(){
    for(var foo in bar) {
        $.each(foo, function(){
            errorval = 3;
            // ALERTS "Needs to be Not set characters long"
            alert(rules.firstRule.message);
        });
    }
});

所以我问我如何在代码中更新errorval,以便rules对象在message属性中具有该新值。

2 个答案:

答案 0 :(得分:5)

这可能会解决您的问题

var errorval = "Not set";
var rules = {
    firstRule : {
        name : 'example',
        getMessage : function() {
          return 'Needs to be '+errorval+' characters long';
        }
    }
}
$('.button').on('click', function(){
    for(var foo in bar) {
        $.each(foo, function(){
            errorval = 3;
            // ALERTS "Needs to be Not set characters long"
            alert(rules.firstRule.getMessage());
        });
    }
});

而不是字符串属性,您调用getMessage方法,该方法根据errorval的当前值返回一个字符串

答案 1 :(得分:0)

这是另一种解决方案,请阅读评论:

var errorval = "Not set";
set(errorval);
$('.button').on('click', function(){
    //for(var foo in bar) {
    //    $.each(foo, function(){
            errorval = 3;
            // you must recall set(errorval) at here for uodate rules object
            alert(rules.firstRule.message);                            
    //    });
    //}
});


function set(errorval){
  rules = {
    firstRule : {
        name : 'example',
        message : 'Needs to be '+errorval+' characters long'
    }
  }
}

Demo