在javascript中嵌套if else

时间:2013-03-20 04:56:59

标签: javascript nested

我在javascript中遇到嵌套if结构的问题。任何帮助表示赞赏。

function validateForm()
{
    var a = document.forms["demo1"]["addr1"].value;
    var b = document.forms["demo1"]["city"].value;
    //var c = document.forms["demo1"]["fname"].value;
    //var d = document.forms["demo1"]["lname"].value;
    //var f = document.forms["demo1"]["phno"].value;
    //var g = document.forms["demo1"]["email"].value;
    //var g1 = document.forms["demo1"]["cemail"].value;
    //var h = document.forms["demo1"]["pwd"].value;
    //var h1 = document.forms["demo1"]["cpwd"].value;
    if(b=="" || b==null)
    {
      alert("Please enter your city");
      return false;
      break;
    }
    else if(a=="" || a==null)
        {
            alert("Please enter your address");
            return false;
            break;
        }
    else {return true;} 
}

<form name = "demo1" action = "exp2.php" onsubmit = "return validateForm()" method = "POST">

如果只有一个if语句,代码可以正常工作(按预期)。但如果部署了多个if else,我就无法得到预期的结果。

此致 摩尼

4 个答案:

答案 0 :(得分:4)

首先,您不需要break语句,在这种情况下它们是无用的。

其次,你不需要嵌套,事实上,你不应该,因为ab的检查是相互独立的:

if(b=="" || b==null)
{
    alert("Please enter your city");
    return false;
}

if(a=="" || a==null)
{
    alert("Please enter your address");
    return false;
}

return true;

答案 1 :(得分:1)

如何使用可重复使用的isEmpty函数缩短代码

function validateForm()
{

    var isEmpty = function ( name , label ){

          var val = document.forms["demo1"][ name ].value;

          if( ! val  )
          {
               alert("Please enter your "+ label );
               return true;     
          }

          return false;

    }         

    return !isEmpty( 'city', 'city') && 
           !isEmpty( 'addr1', 'address');

}

isEmpty返回truefalse

答案 2 :(得分:0)

就像paxdiablo所说,你可以使用两个单独的if语句。

但是如果您只想在输入城市时需要地址,您必须意识到这不是嵌套的if语句。这是:

if(b=="" || b==null)
{
  alert("Please enter your city");
  return false;
}
else 
{
    if(a=="" || a==null)
    {
        alert("Please enter your address");
        return false;
    }
    else 
    {
        return true;
    }
}

更可重复的版本是imo:

if(b=="" || b==null)
{
  alert("Please enter your city");
  return false;
}

if((b=="" || b == null) && (a=="" || a==null))
{
    alert("Please enter your address");
    return false;
}

答案 3 :(得分:0)

if(b=="" || b==null) {
alert("Please enter your city");
return false;
}
else if(a=="" || a==null) {
alert("Please enter your address");
return false;
}
else {
return true;
}