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



我在函数顶部定义了一个变量,并且一个直接在该函数下引用该变量的JSON对象。单击事件,几个循环和一个匿名函数后来我更新第一个变量的值,然后引用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属性中具有新值。

这可能会解决您的问题

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的当前值

返回字符串

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

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

相关内容

  • 没有找到相关文章

最新更新