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

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

浏览次数:
作者: 墨鱼
信息来源: 本站原创
更新日期: 2015-04-23 15:05:54
文章简介

本文提供了多种JavaScript代码方案,详细讲解如何判断表单提交时各项内容不能为空。无论是初学者还是有一定经验的开发者,都能在这里找到适合自己的解决方案,确保表单数据的完整性和准确性。

  • 正文开始
  • 相关阅读
  • 推荐作品

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

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

多说自定义CSS 背景、按钮、字体、隐藏版权
« 上一篇 2015年04月09日
amaze UI – 简单灰色(简灰)多说CSS样式分享
下一篇 » 2015年04月24日
  • 帝国CMS统计多个数据表今日更新总数代码
    40阅读0条评论0个赞
    帝国CMS统计多表今日更新总数代码教程:通过SQL查询结合帝国CMS函数,汇总多个数据表中今日更新的记录总数。步骤包括编写SQL联合查询语句,利用`DATE()`函数筛选今日数据,结合帝国CMS的数据库操作函数执行查询,并输出结果。此教程教你高效获取多表今日更新概况,优化管理效率。
  • 自动识别图片颜色代码,PHP版本
    68阅读0条评论1个赞
    自动识别图片颜色代码PHP教程:学习如何用PHP脚本自动提取图片中的颜色代码。无需手动选取,脚本自动分析图片像素,输出主要颜色或特定颜色代码。适合网页设计师和开发者,快速获取配色方案。通过简单步骤,加载图片、运行脚本,即可获取颜色信息。提升工作效率,让颜色识别自动化。本教程简洁明了,适合初学者快速上手。
  • 帝国cms7.5无刷新 Ajax 点击加载更多列表信息源代码
    730阅读2条评论10个赞
    帝国CMS 7.5 Ajax无刷新加载,高效实现点击加载更多列表信息,精简源码仅展示核心功能,优化用户体验,提升网页加载效率。
  • jquery/js通过当前URL对当前栏目链接高亮显示
    125阅读0条评论4个赞
    通过jQuery/JS技术,可实现对当前URL匹配的栏目链接自动高亮显示。这一功能提升了用户导航体验,使其能够更快速、更准确地定位到所需内容,有效提高了网页的易用性和交互性。
  • 表单checkbox和submit互动:必须先勾选注册协议,注册按钮才可点击
    87阅读0条评论6个赞
    注册页面优化:为提升用户体验,我们现对表单进行升级。勾选注册协议成为必要步骤,确保您了解并同意相关条款。完成勾选后,注册按钮方可激活,助您顺利完成注册流程。

如本文对您有帮助,就请墨鱼抽根烟吧!