正则表达式在javascript中的几个实例
程序员文章站
2022-03-03 11:44:12
! 去除字符串两端空格的处理如果采用传统的方式,就要可能就要采用下面的方式了//清除左边空格function js_ltrim(deststr){if(deststr==n...
! 去除字符串两端空格的处理
如果采用传统的方式,就要可能就要采用下面的方式了
//清除左边空格
function js_ltrim(deststr)
{
if(deststr==null)return "";
var pos=0;
var retstr=new string(deststr);
if (retstr.lenght==0) return retstr;
while (retstr.substring(pos,pos+1)==" ") pos++;
retstr=retstr.substring(pos);
return(retstr);
}
//清除右边空格
function js_rtrim(deststr)
{
if(deststr==null)return "";
var retstr=new string(deststr);
var pos=retstr.length;
if (pos==0) return retstr;
while (pos && retstr.substring(pos-1,pos)==" " ) pos--;
retstr=retstr.substring(0,pos);
return(retstr);
}
//清除左边和右边空格
function js_trim(deststr)
{
if(deststr==null)return "";
var retstr=new string(deststr);
var pos=retstr.length;
if (pos==0) return retstr;
retstr=js_ltrim(retstr);
retstr=js_rtrim(retstr);
return retstr;
}
采用正则表达式,来去除两边的空格,只需以下代码
string.prototype.trim = function()
{
return this.replace(/(^\s*)|(\s*$)/g, "");
}
一句就搞定了,
可见正则表达式为我们节省了相当的编写代码量
! 移动手机号的校验
如果采用传统的校验方式至少就要完成下面三步的校验,
(1). 是否是数字
(2).是否是11位
(3).数字的第三位是否是5,6,7,8,9
如果采用正则表达式校验,只需以下代码
function checkmobile1(form)
{
if (form.mobile.value > "")
{
var reg=/13[5,6,7,8,9]\d{8}/;
if ( form.mobile.value.match(reg)== null)
{
alert("请输入正确的移动手机号码!");
form.mobile.focus(); return false;
}
}
return true;
}
从上面的代码可以看出校验移动手机号只需定义一个var reg=/13[5,6,7,8,9]\d{8}/;模式匹配串就可以完成合法性校验了
! url的校验,
条件:必须以 或 开头, 端口号必须为在1-65535 之间, 以下代码完成了合法性校验
//obj:数据对象
//dispstr :失败提示内容显示字符串
function checkurlvalid( obj, dispstr)
{
if(obj == null)
{
alert("传入对象为空");
return false;
}
var str = obj.value;
var urlpatern0 = /^https?:\/\/.+$/i;
if(!urlpatern0.test(str))
{
alert(dispstr+"不合法:必须以'http:\/\/'或'https:\/\/'开头!");
obj.focus();
return false;
}
var urlpatern2= /^https?:\/\/(([a-za-z0-9_-])+(\.)?)*(:\d+)?.+$/i;
if(!urlpatern2.test(str))
{
alert(dispstr+"端口号必须为数字且应在1-65535之间!");
obj.focus();
return false;
}
var urlpatern1 =/^https?:\/\/(([a-za-z0-9_-])+(\.)?)*(:\d+)?(\/((\.)?(\?)?=?&?[a-za-z0-9_-](\?)?)*)*$/i;
if(!urlpatern1.test(str))
{
alert(dispstr+"不合法,请检查!");
obj.focus();
return false;
}
var s = "0";
var t =0;
var re = new regexp(":\\d+","ig");
while((arr = re.exec(str))!=null)
{
s = str.substring(regexp.index+1,regexp.lastindex);
if(s.substring(0,1)=="0")
{
alert(dispstr+"端口号不能以0开头!");
obj.focus();
return false;
}
t = parseint(s);
if(t<1 || t >65535)
{
alert(dispstr+"端口号必须为数字且应在1-65535之间!");
obj.focus();
return false;
}
}
return true;
}
对url的校验,看上去有很多的代码,这是因为要给予出错提示, 否则只需var urlpatern1 =/^https?:\/\/(([a-za-z0-9_-])+(\.)?)*(:\d+)?(\/((\.)?(\?)?=?&?[a-za-z0-9_-](\?)?)*)*$/i; 一句就可以校验出url合法性了
javascript正则表达式检验
/*********************************************************************************
* eo_jslib.js
* javascript正则表达式检验
**********************************************************************************/
//校验是否全由数字组成
function isdigit(s)
{
var patrn=/^[0-9]{1,20}$/;
if (!patrn.exec(s)) return false
return true
}
//校验登录名:只能输入5-20个以字母开头、可带数字、“_”、“.”的字串
function isregisterusername(s)
{
var patrn=/^[a-za-z]{1}([a-za-z0-9]|[._]){4,19}$/;
if (!patrn.exec(s)) return false
return true
}
//校验用户姓名:只能输入1-30个以字母开头的字串
function istruename(s)
{
var patrn=/^[a-za-z]{1,30}$/;
if (!patrn.exec(s)) return false
return true
}
//校验密码:只能输入6-20个字母、数字、下划线
function ispasswd(s)
{
var patrn=/^(\w){6,20}$/;
if (!patrn.exec(s)) return false
return true
}
//校验普通电话、传真号码:可以“+”开头,除数字外,可含有“-”
function istel(s)
{
//var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?(\d){1,12})+$/;
var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/;
if (!patrn.exec(s)) return false
return true
}
//校验手机号码:必须以数字开头,除数字外,可含有“-”
function ismobil(s)
{
var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/;
if (!patrn.exec(s)) return false
return true
}
//校验邮政编码
function ispostalcode(s)
{
//var patrn=/^[a-za-z0-9]{3,12}$/;
var patrn=/^[a-za-z0-9 ]{3,12}$/;
if (!patrn.exec(s)) return false
return true
}
//校验搜索关键字
function issearch(s)
{
var patrn=/^[^`~!@#$%^&*()+=|\\\][\]\{\}:;'\,.<>/?]{1}[^`~!@$%^&()+=|\\\][\]\{\}:;'\,.<>?]{0,19}$/;
if (!patrn.exec(s)) return false
return true
}
function isip(s) //by zergling
{
var patrn=/^[0-9.]{1,20}$/;
if (!patrn.exec(s)) return false
return true
}
如果采用传统的方式,就要可能就要采用下面的方式了
//清除左边空格
function js_ltrim(deststr)
{
if(deststr==null)return "";
var pos=0;
var retstr=new string(deststr);
if (retstr.lenght==0) return retstr;
while (retstr.substring(pos,pos+1)==" ") pos++;
retstr=retstr.substring(pos);
return(retstr);
}
//清除右边空格
function js_rtrim(deststr)
{
if(deststr==null)return "";
var retstr=new string(deststr);
var pos=retstr.length;
if (pos==0) return retstr;
while (pos && retstr.substring(pos-1,pos)==" " ) pos--;
retstr=retstr.substring(0,pos);
return(retstr);
}
//清除左边和右边空格
function js_trim(deststr)
{
if(deststr==null)return "";
var retstr=new string(deststr);
var pos=retstr.length;
if (pos==0) return retstr;
retstr=js_ltrim(retstr);
retstr=js_rtrim(retstr);
return retstr;
}
采用正则表达式,来去除两边的空格,只需以下代码
string.prototype.trim = function()
{
return this.replace(/(^\s*)|(\s*$)/g, "");
}
一句就搞定了,
可见正则表达式为我们节省了相当的编写代码量
! 移动手机号的校验
如果采用传统的校验方式至少就要完成下面三步的校验,
(1). 是否是数字
(2).是否是11位
(3).数字的第三位是否是5,6,7,8,9
如果采用正则表达式校验,只需以下代码
function checkmobile1(form)
{
if (form.mobile.value > "")
{
var reg=/13[5,6,7,8,9]\d{8}/;
if ( form.mobile.value.match(reg)== null)
{
alert("请输入正确的移动手机号码!");
form.mobile.focus(); return false;
}
}
return true;
}
从上面的代码可以看出校验移动手机号只需定义一个var reg=/13[5,6,7,8,9]\d{8}/;模式匹配串就可以完成合法性校验了
! url的校验,
条件:必须以 或 开头, 端口号必须为在1-65535 之间, 以下代码完成了合法性校验
//obj:数据对象
//dispstr :失败提示内容显示字符串
function checkurlvalid( obj, dispstr)
{
if(obj == null)
{
alert("传入对象为空");
return false;
}
var str = obj.value;
var urlpatern0 = /^https?:\/\/.+$/i;
if(!urlpatern0.test(str))
{
alert(dispstr+"不合法:必须以'http:\/\/'或'https:\/\/'开头!");
obj.focus();
return false;
}
var urlpatern2= /^https?:\/\/(([a-za-z0-9_-])+(\.)?)*(:\d+)?.+$/i;
if(!urlpatern2.test(str))
{
alert(dispstr+"端口号必须为数字且应在1-65535之间!");
obj.focus();
return false;
}
var urlpatern1 =/^https?:\/\/(([a-za-z0-9_-])+(\.)?)*(:\d+)?(\/((\.)?(\?)?=?&?[a-za-z0-9_-](\?)?)*)*$/i;
if(!urlpatern1.test(str))
{
alert(dispstr+"不合法,请检查!");
obj.focus();
return false;
}
var s = "0";
var t =0;
var re = new regexp(":\\d+","ig");
while((arr = re.exec(str))!=null)
{
s = str.substring(regexp.index+1,regexp.lastindex);
if(s.substring(0,1)=="0")
{
alert(dispstr+"端口号不能以0开头!");
obj.focus();
return false;
}
t = parseint(s);
if(t<1 || t >65535)
{
alert(dispstr+"端口号必须为数字且应在1-65535之间!");
obj.focus();
return false;
}
}
return true;
}
对url的校验,看上去有很多的代码,这是因为要给予出错提示, 否则只需var urlpatern1 =/^https?:\/\/(([a-za-z0-9_-])+(\.)?)*(:\d+)?(\/((\.)?(\?)?=?&?[a-za-z0-9_-](\?)?)*)*$/i; 一句就可以校验出url合法性了
javascript正则表达式检验
/*********************************************************************************
* eo_jslib.js
* javascript正则表达式检验
**********************************************************************************/
//校验是否全由数字组成
function isdigit(s)
{
var patrn=/^[0-9]{1,20}$/;
if (!patrn.exec(s)) return false
return true
}
//校验登录名:只能输入5-20个以字母开头、可带数字、“_”、“.”的字串
function isregisterusername(s)
{
var patrn=/^[a-za-z]{1}([a-za-z0-9]|[._]){4,19}$/;
if (!patrn.exec(s)) return false
return true
}
//校验用户姓名:只能输入1-30个以字母开头的字串
function istruename(s)
{
var patrn=/^[a-za-z]{1,30}$/;
if (!patrn.exec(s)) return false
return true
}
//校验密码:只能输入6-20个字母、数字、下划线
function ispasswd(s)
{
var patrn=/^(\w){6,20}$/;
if (!patrn.exec(s)) return false
return true
}
//校验普通电话、传真号码:可以“+”开头,除数字外,可含有“-”
function istel(s)
{
//var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?(\d){1,12})+$/;
var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/;
if (!patrn.exec(s)) return false
return true
}
//校验手机号码:必须以数字开头,除数字外,可含有“-”
function ismobil(s)
{
var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/;
if (!patrn.exec(s)) return false
return true
}
//校验邮政编码
function ispostalcode(s)
{
//var patrn=/^[a-za-z0-9]{3,12}$/;
var patrn=/^[a-za-z0-9 ]{3,12}$/;
if (!patrn.exec(s)) return false
return true
}
//校验搜索关键字
function issearch(s)
{
var patrn=/^[^`~!@#$%^&*()+=|\\\][\]\{\}:;'\,.<>/?]{1}[^`~!@$%^&()+=|\\\][\]\{\}:;'\,.<>?]{0,19}$/;
if (!patrn.exec(s)) return false
return true
}
function isip(s) //by zergling
{
var patrn=/^[0-9.]{1,20}$/;
if (!patrn.exec(s)) return false
return true
}
上一篇: 微信小程序倒计时功能实现代码
下一篇: 正则表达式在UBB论坛中的应用
推荐阅读
-
在numpy矩阵中令小于0的元素改为0的实例
-
web在html中引用JavaScript代码的实现(小程序在xwml中实现)
-
详解适配器在JavaScript中的体现
-
Linux 在Bash脚本中怎么关闭文件描述符的实例
-
浅谈JavaScript中的正则表达式(适用初学者观看)
-
在JavaScript应用中实现延迟加载的方法
-
详解JavaScript 中getElementsByName在IE中的注意事项
-
在javascript中,null>=0 为真,null==0却为假,null的值详解
-
在Pandas中DataFrame数据合并,连接(concat,merge,join)的实例
-
在JavaScript中重写jQuery对象的方法教程实例教程教程