返回字符串
我在函数顶部定义了一个变量,并且一个直接在该函数下引用该变量的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