javascriptRegex執行個體

來源:互聯網
上載者:User

! 去除字串兩端空格的處理

如果採用傳統的方式,就要可能就要採用下面的方式了
//清除左邊空格
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;
}

採用Regex,來去除兩邊的空格,只需以下代碼
String.prototype.trim = function()
{
return this.replace(/(^/s*)|(/s*$)/g, "");
}

一句就搞定了,
可見Regex為我們節省了相當的編寫代碼量

! 移動手機號的校正

如果採用傳統的校正方式至少就要完成下面三步的校正,
(1). 是否是數字
(2).是否是11位
(3).數位第三位是否是5,6,7,8,9
如果採用Regex校正,只需以下代碼
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的校正,
條件:必須以http:// 或 https:// 開頭, 連接埠號碼必須為在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合法性了

**********************************************************************************/

//校正是否全由數字組成
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
}

<script type="text/javascript"></script><script type="text/javascript"></script>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.