我有一个在我的函数顶部定义的变量和一个直接在其下引用该变量的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
属性中具有该新值。
答案 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'
}
}
}