
正在做前端时我们希望用户按要求提交数据了,如果提交了空我们就需要进入提示,正在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;
}
经过测试第五种圆法正在处理长字符串时效率最高。
转载请注明: 帝国CMS模板 » JS判定提交表单不克不及为空代码 多种圆案
*
回帖描述:*
链接类型:*
下载链接:*
描述:*
回帖描述:*
链接类型:*
阅读权限:*
下载链接:



聚优部落技术论坛 © 版权所有 鲁ICP备15007479号-6
Copyright(C)web.com, All Rights Reserved.
