这应该是一个简单的,但现在让我头痛两天了。 我有以下内容:
<a href="javascript:void();" onclick="return manage(id, value)">Add or remove</a>
管理功能如下
function manage(id, param){
var my_value;
alert(my_value); // this keeps giving me undefined. I want it to hold the last value of the param
if(param!=0){ // value not empty, we are removing
my_value = remValue(id, param);
}
else if(param==''){ // value is empty, so we are adding
my_value = addValue(id, param);
}
alert(my_value);
}
function addValue(id, param){
param += 1;
return param;
}
function remValue(id, param){
param -= 1;
return param;
}
整个想法是在添加或删除操作后将param的值赋给my_value。有什么帮助吗?
答案 0 :(得分:4)
通过在函数中定义var my_value;
,您可以在每次函数调用时将变量重新声明为未定义的值。它仅限于该呼叫本地,并且不会持续存在。
如果您需要它来保留该值,您只需要在更高的范围内使用var
声明它:
// Declare outside the function...
var my_value;
function manage(id, param){
alert(my_value); // Should be undefined on first call,
// or hold previous value on subsequent calls after assignment
if(param!=0){ // value not empty, we are removing
my_value = remValue(id, param);
}
else if(param==''){ // value is empty, so we are adding
my_value = addValue(id, param);
}
alert(my_value);
}