要求输入的长度为5-15位,结果输入小于5位的长度时弹出错误提示,大于15位却不能弹出,何故?
<html>
<head>
<title></title>
<meta http-equiv="Content-Type" content="text/html;charset=GBK">
<script language="javascript">
function validate(f) {
if (!(/\w{5,15}/.test(f.name.value))) {
alert("用户名必须是5-15位");
f.name.focus();
return false;
}
return true;
}
</script>
</head>
<body>
<form method="post" action="" onSubmit="return validate(this)">
<input type="text" name="name" size="20" maxlength="20">
<input type="submit" value="提交">
</form>
</body>
</html>

解决方案 »

  1.   

     if (!(/^\w{5,15}$/.test(f.name.value))) {
                alert("用户名必须是5-15位");
                f.name.focus();
                return false;
            }
      

  2.   

    if (!(/^\w{5,15}$/).test(f.name.value))) {
                alert("用户名必须是5-15位");
                f.name.focus();
                return false;
            }
      

  3.   

    if(f.name.value.length < 5 && f.name.value.length > 15){
     alert("用户名必须是5-15位");
      f.name.focus();
      return false;
    }
    这样比较明了,刚开始学我是用这个的,但学了正则,就可以用强大的正则表达式啦
      

  4.   

    if(f.name.value.length < 5 || f.name.value.length > 15){
     alert("用户名必须是5-15位");
      f.name.focus();
      return false;
    }
    这样才对