网站地图    收藏   

主页 > 前端 > javascript >

JS判断提交表单不能为空代码

来源:自学PHP网    时间:2014-09-19 14:47 作者: 阅读:

[导读] 在做前端时我们希望用户按要求提交数据了,如果提交了空我们就需要进入提示,在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;  

经过测试第五种方法在处理长字符串时效率最高。

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论