加入收藏 | 设为首页 | 会员中心 | 我要投稿 宿州站长网 (https://www.0557zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 建站 > 正文

JS判断提交表单不能为空代码 多种方法

发布时间:2022-04-28 11:23:27 所属栏目:建站 来源:互联网
导读:在做前端时我们希望用户按要求提交数据了,如果提交了空我们就需要进入提示,在js中判断表单为空我们直接使用xx==空就可以了,下面看实例。 html script language=JavaScript function checkpost() { if(myform.keywords.value==){alert(请输入内容); myform
         在做前端时我们希望用户按要求提交数据了,如果提交了空我们就需要进入提示,在js中判断表单为空我们直接使用xx==空就可以了,下面看实例。
 
         <html> <script language="JavaScript"> function checkpost() {    if(myform.keywords.value==""){alert("请输入内容");     myform.keywords.focus();     return false;        }    if(myform.title.value.length<5){alert("请输入标题");     myform.title.focus();     return false;        } } </script><form          action=search.php name="myform" onsubmit="return checkpost();"> 关键字:<input type="text" name="keywords"><br> 标题:<input type="text" name="title"> <input type="submit" value="查询"> </form>  </html>
         解释:
 
         表单中onsubmit 控制提交后事件,return函数执行表单提交函数 值为false不提交,为true提交。然后用JS制作一个checkpost函数,来得到是false和ture.JS代码中myform.title.focus(); 表示鼠标的焦点在title上myform.title.value.length<5表示title字段中,长度小于5时,警告和不执行
  
         如果我们直接按几个空格进去,上面的代码肯定是可以通过的因为空格是字符串并不是空哦,我们可通过下面方法修正
 
第一种:循环检查替换
 
[javascript]
 
//供使用者调用  function trim(s){  return trimRight(trimLeft(s));  }  //去掉左边的空白  function trimLeft(s){  if(s == null) {  return "";  }  var whitespace = new String(" tnr");  var str = new String(s);  if (whitespace.indexOf(str.charAt(0)) != -1) {  var j=0, i = str.length;  while (j < i && whitespace.indexOf(str.charAt(j)) != -1){  j++;  }  str = str.substring(j, i);  }  return str;  }  //去掉右边的空白 www.111cn.net   function trimRight(s){  if(s == null) return "";  var whitespace = new String(" tnr");  var str = new String(s);  if (whitespace.indexOf(str.charAt(str.length-1)) != -1){  var i = str.length - 1;  while (i >= 0 && whitespace.indexOf(str.charAt(i)) != -1){  i--;  }  str = str.substring(0, i+1);  }  return str;  }
第二种:正则替换
 
[javascript]
 
<SCRIPT LANGUAGE="JavaScript">  <!--  String.prototype.Trim = function()  {  return this.replace(/(^s*)|(s*$)/g, "");  }  String.prototype.LTrim = function()  {  return this.replace(/(^s*)/g, "");  }  String.prototype.RTrim = function()  {  return this.replace(/(s*$)/g, "");  }  //-->  </SCRIPT>
第三种:使用jquery
 
[javascript]
 
$.trim(str)
jquery内部实现为:
 
[javascript]
 
function trim(str){       return str.replace(/^(s|u00A0)+/,'').replace(/(s|u00A0)+$/,'');   }
第四种:使用motools
 
[javascript]
 
function trim(str){       return str.replace(/^(s|xA0)+|(s|xA0)+$/g, '');   }
第五种:裁剪字符串方式
 
[javascript]
 
function trim(str){       str = str.replace(/^(s|u00A0)+/,'');       for(var i=str.length-1; i>=0; i--){           if(/S/.test(str.charAt(i))){               str = str.substring(0, i+1);               break;           }       }       return str;   }
经过测试第五种方法在处理长字符串时效率最高。

(编辑:宿州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!