动态更改javascript功能

时间:2012-08-29 18:32:03

标签: javascript javascript-events

这应该是一个简单的,但现在让我头痛两天了。 我有以下内容:

<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。有什么帮助吗?

1 个答案:

答案 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);    
}