JS判断提交表单不能为空代码
例
代码如下 | |
<html> <form action=search.php name="myform" onsubmit="return checkpost();"> |
解释:
表单中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; } |
经过测试第五种方法在处理长字符串时效率最高。