关于函数return的返回值获取的问题

我写了一个表单提交的方法,代码如下:
function validate(){

    var name=document.getElementById("name_txt");
    var power=document.getElementById("power_txt");
    var error="輸入有誤!";
    (function Error(){
        if (name.value==""||power.value==""){
            return error;
        }else{
            return;
        }
    })();
    return Error(error);
}
document.getElementById("submit").onclick=function(){
    validate();
    if(error){//就是这里,为何没有获取到error?
        alert("輸入有誤!");
        return false;
    }else{
        return true;
        document.getElementById("login_form").submit();
    }
}

然而并没有效果,我想问的是validate方法内的那个闭包,为什么return没有结果?意思就是那个闭包调用完成后,那个结果怎么能获取到(submit.onclick()方法就是希望获取到那个闭包的结果,根据结果来判断表单是否提交),求指教。当然,要完成这个需求,肯定有其他的方式,但是不作考虑(这个脱了裤子放屁的方式是为了练习,感受函数传值)

阅读 4.3k
3 个回答

感觉怪怪的,if(!validate()) {...} else {...},你代码中如果name和power的value不为空时,没有返回结果,为空啊

不太懂你在干嘛...

validate() 里写了个立即执行函数,先不谈为什么要用 Error 这个 javascript 已存在的方法名,那个闭包实际没任何用处。所以 return 依然执行的是原生的 Error(),Error(error) 是 undefined。

function validate(){
    var name=document.getElementById("name_txt");
    var power=document.getElementById("power_txt");
    var C="輸入有誤!";
    var result = "";
    (function cuowu(){
        if (name.value==""||power.value==""){
            result = C;
        }else{
            result = null;
        }
    })();
    return result;
}
document.getElementById("submit").onclick=function(){
    var result = validate();
    if(result){
        alert("輸入有誤!");
        return false;
    }else{
        return true;
        document.getElementById("login_form").submit();
    }
}

我的代码可能确实有问题,其实我的需求就是想subobj.onclick方法能够获取到validate下面的自调用函数的结果(return的内容)如你所说,我修改了代码:
function validate(){

    var name=document.getElementById("name_txt");
    var power=document.getElementById("power_txt");
    var C="輸入有誤!";
    (function cuowu(){
        if (name.value==""||power.value==""){
            return C;
        }else{
            return;
        }
    })();
    //在这里我不知道应该怎么来保持、接受上面自调用函数的结果
}
document.getElementById("submit").onclick=function(){
    validate();
    if(C){//这里保错了:C没有定义(not defined)
        alert("輸入有誤!");
        return false;
    }else{
        return true;
        document.getElementById("login_form").submit();
    }
}
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题