js表單驗證大全

    今天瀏覽偶爾發現了一個這樣的帖子,就摘錄了下來,之後遇到相似的問題就能重用了,這就是代碼重用啊,呵呵。javascript

 關鍵字:js驗證表單大全,用JS控制表單提交 ,javascript提交表單:html

 

目錄:java

1:js 字符串長度限制、判斷字符長度 、js限制輸入、限制不能輸入、textarea 長度限制 node

2.:js判斷漢字、判斷是否漢字 、只能輸入漢字正則表達式

3:js判斷是否輸入英文、只能輸入英文函數

4:js只能輸入數字,判斷數字、驗證數字、檢測數字、判斷是否爲數字、只能輸入數字工具

5:只能輸入英文字符和數字測試

6: js email驗證 、js 判斷email 、信箱/郵箱格式驗證編碼

7:js字符過濾,屏蔽關鍵字orm

8:js密碼驗證、判斷密碼 

2.1: js 不爲空、爲空或不是對象 、判斷爲空 、判斷不爲空 

2.2:比較兩個表單項的值是否相同

2.3:表單只能爲數字和"_",

2.4:表單項輸入數值/長度限定

2.5:中文/英文/數字/郵件地址合法性判斷

2.6:限定表單項不能輸入的字符

2.7表單的自符控制

2.8:form文本域的通用校驗函數

1. 長度限制

<script>

function test() 

{

if(document.a.b.value.length>50)

{

alert("不能超過50個字符!");

document.a.b.focus();

return false;

}

}

</script>

<form test()">

<textarea cols="40" wrap="VIRTUAL" rows="6"></textarea>

<input type="submit" value="check">

</form> 

2. 只能是漢字 

<input /oblog/value.replace(/[^\u4E00-\u9FA5]/g,'')">

3." 只能是英文

<script language=javascript>

function onlyEng()

{

if(!(event.keyCode>=65&&event.keyCode<=90))

event.returnvalue=false;

}

</script>

<input >

4. 只能是數字

<script language=javascript>

function onlyNum()

{

if(!((event.keyCode>=48&&event.keyCode<=57)||(event.keyCode>=96&&event.keyCode<=105)))

//考慮小鍵盤上的數字鍵

event.returnvalue=false;

}

</script>

<input >

5. 只能是英文字符和數字

<input /oblog/value.replace(/[\W]/g,"'') "text',clipboardData.getData('text').replace(/[^\d]/g,''))">

6. 驗證油箱格式

<SCRIPT LANGUAGE=javascript RUNAT=Server>

function isEmail(strEmail) {

if (strEmail.search(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/) != -1)

return true;

else

alert("oh");

}

</SCRIPT>

<input type=text

7. 屏蔽關鍵字(這裏屏蔽***和****)

<script language="javascript1.2">

function test() {

if((a.b.value.indexOf ("***") == 0)||(a.b.value.indexOf ("****") == 0)){

alert(":)");

a.b.focus();

return false;}

}

</script>

<form test()">

<input type=text

<input type="submit" value="check">

</form>

8. 兩次輸入密碼是否相同

<FORM METHOD=POST ACTION="">

<input type="password" >

<input type="password" >

<input type="button" value="test" >

</FORM>

<script>

function check()

with(document.all){

if(input1.value!=input2.value)

{

alert("false")

input1.value = "";

input2.value = "";

}

else document.forms[0].submit();

}

}

</script>

夠了吧 :)

屏蔽右鍵 很酷 

oncontextmenu="return false" false" false"

加在body中

2.1  表單項不能爲空

<script  language="javascript">

<!--

function  CheckForm()

{  

if  (document.form.name.value.length  ==  0)  {  

alert("請輸入您姓名!");

document.form.name.focus();

return  false;

}

return  true;

}

-->

</script>

2.2  比較兩個表單項的值是否相同

<script  language="javascript">

<!--

function  CheckForm()

if  (document.form.PWD.value  !=  document.form.PWD_Again.value)  {  

alert("您兩次輸入的密碼不同!請從新輸入.");

document.ADDUser.PWD.focus();

return  false;

}

return  true;

}

-->

</script>

2.3  表單項只能爲數字和"_",用於電話/銀行賬號驗證上,可擴展到域名註冊等

<script  language="javascript">

<!--

function  isNumber(String)

{  

var  Letters  =  "1234567890-";  //能夠本身增長可輸入值

var  i;

var  c;

if(String.charAt(  0  )=='-')

return  false;

if(  String.charAt(  String.length  -  1  )  ==  '-'  )

return  false;

for(  i  =  0;  i  <  String.length;  i  ++  )

{  

c  =  String.charAt(  i  );

if  (Letters.indexOf(  c  )  <  0)

return  false;

}

return  true;

}

function  CheckForm()

{  

if(!  isNumber(document.form.TEL.value))  {  

alert("您的電話號碼不合法!");

document.form.TEL.focus();

return  false;

}

return  true;

}

-->

</script>

2.4  表單項輸入數值/長度限定

<script  language="javascript">

<!--

function  CheckForm()  

{  

if  (document.form.count.value  >  100  ||  document.form.count.value  <  1)

{  

alert("輸入數值不能小於零大於100!");

document.form.count.focus();

return  false;

}

if  (document.form.MESSAGE.value.length<10)

{  

alert("輸入文字小於10!");

document.form.MESSAGE.focus();

return  false;

}

return  true;

}

//-->

</script>

2.5  中文/英文/數字/郵件地址合法性判斷

<SCRIPT  LANGUAGE="javascript">

<!--

function  isEnglish(name)  //英文值檢測

{  

if(name.length  ==  0)

return  false;

for(i  =  0;  i  <  name.length;  i++)  {  

if(name.charCodeAt(i)  >  128)

return  false;

}

return  true;

}

function  isChinese(name)  //中文值檢測

{  

if(name.length  ==  0)

return  false;

for(i  =  0;  i  <  name.length;  i++)  {  

if(name.charCodeAt(i)  >  128)

return  true;

}

return  false;

}

function  isMail(name)  //  E-mail值檢測

{  

if(!  isEnglish(name))

return  false;

i  =  name.indexOf("  at  ");

j  =  name  dot  lastIndexOf("  at  ");

if(i  ==  -1)

return  false;

if(i  !=  j)

return  false;

if(i  ==  name  dot  length)

return  false;

return  true;

}

function  isNumber(name)  //數值檢測

{  

if(name.length  ==  0)

return  false;

for(i  =  0;  i  <  name.length;  i++)  {  

if(name.charAt(i)  <  "0"  ||  name.charAt(i)  >  "9")

return  false;

}

return  true;

}

function  CheckForm()

{  

if(!  isMail(form.Email.value))  {  

alert("您的電子郵件不合法!");

form.Email.focus();

return  false;

}

if(!  isEnglish(form.name.value))  {  

alert("英文名不合法!");

form.name.focus();

return  false;

}

if(!  isChinese(form.cnname.value))  {  

alert("中文名不合法!");

form.cnname.focus();

return  false;

}

if(!  isNumber(form.PublicZipCode.value))  {  

alert("郵政編碼不合法!");

form.PublicZipCode.focus();

return  false;

}

return  true;

}

//-->

</SCRIPT>

2.6  限定表單項不能輸入的字符

<script  language="javascript">

<!--

function  contain(str,charset)//  字符串包含測試函數

{  

var  i;

for(i=0;i<charset.length;i++)

if(str.indexOf(charset.charAt(i))>=0)

return  true;

return  false;

}

function  CheckForm()

{  

if  ((contain(document.form.NAME.value,  "%\(\)><"))  ||  (contain(document.form.MESSAGE.value,  "%\(\)><")))

{  

alert("輸入了非法字符");

document.form.NAME.focus();

return  false;

}

return  true;

}

//-->

</script>  

1. 檢查一段字符串是否全由數字組成       

---------------------------------------       

<script language="Javascript"><!--           

function checkNum(str){return str.match(/\D/)==null}           

alert(checkNum("1232142141"))           

alert(checkNum("123214214a1"))           

// --></script>         

2. 怎麼判斷是不是字符         

---------------------------------------       

if (/[^\x00-\xff]/g.test(s)) alert("含有漢字");          

else alert("全是字符");      

3. 怎麼判斷是否含有漢字        

---------------------------------------        

if (escape(str).indexOf("%u")!=-1) alert("含有漢字");         

else alert("全是字符");           

4. 郵箱格式驗證    

---------------------------------------      

//函數名:chkemail     

//功能介紹:檢查是否爲Email Address     

//參數說明:要檢查的字符串     

//返回值:0:不是 1:是     

function chkemail(a)     

{ var i=a.length;     

var temp = a.indexOf('@');     

var tempd = a.indexOf('.');     

if (temp > 1) {     

if ((i-temp) > 3){     

if ((i-tempd)>0){     

return 1;     

}     

}     

}     

return 0;     

}     

    

5. 數字格式驗證    

---------------------------------------      

//函數名:fucCheckNUM     

//功能介紹:檢查是否爲數字     

//參數說明:要檢查的數字     

//返回值:1爲是數字,0爲不是數字     

function fucCheckNUM(NUM)     

{     

var i,j,strTemp;     

strTemp="0123456789";     

if ( NUM.length== 0)     

return 0     

for (i=0;i<NUM.length;i++)     

{     

j=strTemp.indexOf(NUM.charAt(i));     

if (j==-1)     

{     

//說明有字符不是數字     

return 0;     

}     

}     

//說明是數字     

return 1;     

}     

6. 電話號碼格式驗證    

---------------------------------------      

//函數名:fucCheckTEL     

//功能介紹:檢查是否爲電話號碼     

//參數說明:要檢查的字符串     

//返回值:1爲是合法,0爲不合法     

function fucCheckTEL(TEL)     

{     

var i,j,strTemp;     

strTemp="0123456789-()# ";     

for (i=0;i<TEL.length;i++)     

{     

j=strTemp.indexOf(TEL.charAt(i));     

if (j==-1)     

{     

//說明有字符不合法     

return 0;     

}     

}     

//說明合法     

return 1;     

}    

7. 判斷輸入是否爲中文的函數   

---------------------------------------      

function ischinese(s){   

var ret=true;   

for(var i=0;i<s.length;i++)   

ret=ret && (s.charCodeAt(i)>=10000);   

return ret;   

}    

8. 綜合的判斷用戶輸入的合法性的函數  

---------------------------------------      

<script language="javascript">  

//限制輸入字符的位數開始  

//m是用戶輸入,n是要限制的位數  

function issmall(m,n)  

{  

if ((m<n) && (m>0))  

  {  

  return(false);  

  }  

else  

{return(true);}  

}  

9. 判斷密碼是否輸入一致  

---------------------------------------      

function issame(str1,str2)  

{  

if (str1==str2)  

{return(true);}  

else  

{return(false);}  

}  

10. 判斷用戶名是否爲數字字母下滑線 

---------------------------------------      

function notchinese(str){ 

var reg=/[^A-Za-z0-9_]/g 

    if (reg.test(str)){ 

    return (false); 

    }else{ 

return(true);    } 

2.8. form文本域的通用校驗函數

---------------------------------------      

做用:檢測全部必須非空的input文本,好比姓名,帳號,郵件地址等等。

該校驗如今只針對文本域,若是要針對form裏面的其餘域對象,能夠改變判斷條件。

使用方法:在要檢測的文本域中加入title文字。文字是在提示信息,你要提示給用戶的該字段的中文名。好比要檢測用戶名

html以下<input title="姓名">,固然,最好用可視化工具好比dreamweaver什麼的來編輯域。

若是要檢測數字類型數據的話,再把域的id統一爲sz.

javascript判斷日期類型比較麻煩,因此就沒有作日期類型校驗的程序了.高手能夠補充。

程序比較草,只是提供一個思路。拋磚引玉! :)

哦,對了,函數調用方法:< form  dovalidate()">

function dovalidate()

{

fm=document.forms[0] //只檢測一個form,若是是多個能夠改變判斷條件

    for(i=0;i<fm.length;i++)

    {  

    //檢測判斷條件,根據類型不一樣能夠修改

    if(fm[i].tagName.toUpperCase()=="INPUT" &&fm[i].type.toUpperCase()=="TEXT" && (fm[i].title!=""))

         if(fm[i].value="/blog/="")//

         {

         str_warn1=fm[i].title+"不能爲空!";

         alert(str_warn1);

        fm[i].focus();

         return false;         

         }

         if(fm[i].id.toUpperCase()=="SZ")//數字校驗

         {

                 if(isNaN(fm[i].value))

                { str_warn2=fm[i].title+"格式不對";

                alert(str_warn2);

                fm[i].focus();

                 return false;

                 }

        }

    }

    return true;

}

用途:校驗ip地址的格式

輸入:strIP:ip地址

返回:若是經過驗證返回true,不然返回false;

*/

function isIP(strIP) {

if (isNull(strIP)) return false;

var re=/^(\d+)\.(\d+)\.(\d+)\.(\d+)$/g //匹配IP地址的正則表達式

if(re.test(strIP))

{

if( RegExp.$1 <256 && RegExp.$2<256 && RegExp.$3<256 && RegExp.$4<256) return true;

}

return false;

}

/*

用途:檢查輸入字符串是否爲空或者所有都是空格

輸入:str

返回:

若是全是空返回true,不然返回false

*/

function isNull( str ){

if ( str == "" ) return true;

var regu = "^[ ]+$";

var re = new RegExp(regu);

return re.test(str);

}

 

/*

用途:檢查輸入對象的值是否符合整數格式

輸入:str 輸入的字符串

返回:若是經過驗證返回true,不然返回false

*/

function isInteger( str ){ 

var regu = /^[-]{0,1}[0-9]{1,}$/;

return regu.test(str);

}

/*

用途:檢查輸入手機號碼是否正確

輸入:

s:字符串

返回:

若是經過驗證返回true,不然返回false

*/

function checkMobile( s ){  

var regu =/^[1][3][0-9]{9}$/;

var re = new RegExp(regu);

if (re.test(s)) {

return true;

}else{

return false;

}

}

 

/*

用途:檢查輸入字符串是否符合正整數格式

輸入:

s:字符串

返回:

若是經過驗證返回true,不然返回false

*/

function isNumber( s ){  

var regu = "^[0-9]+$";

var re = new RegExp(regu);

if (s.search(re) != -1) {

return true;

} else {

return false;

}

}

/*

用途:檢查輸入字符串是不是帶小數的數字格式,能夠是負數

輸入:

s:字符串

返回:

若是經過驗證返回true,不然返回false

*/

function isDecimal( str ){  

if(isInteger(str)) return true;

var re = /^[-]{0,1}(\d+)[\.]+(\d+)$/;

if (re.test(str)) {

if(RegExp.$1==0&&RegExp.$2==0) return false;

return true;

} else {

return false;

}

}

/*

用途:檢查輸入對象的值是否符合端口號格式

輸入:str 輸入的字符串

返回:若是經過驗證返回true,不然返回false

*/

function isPort( str ){ 

return (isNumber(str) && str<65536);

}

/*

用途:檢查輸入對象的值是否符合E-Mail格式

輸入:str 輸入的字符串

返回:若是經過驗證返回true,不然返回false

*/

function isEmail( str ){ 

var myReg = /^[-_A-Za-z0-9]+@([_A-Za-z0-9]+\.)+[A-Za-z0-9]{2,3}$/;

if(myReg.test(str)) return true;

return false;

}

/*

用途:檢查輸入字符串是否符合金額格式

格式定義爲帶小數的正數,小數點後最多三位

輸入:

s:字符串

返回:

若是經過驗證返回true,不然返回false

*/

function isMoney( s ){  

var regu = "^[0-9]+[\.][0-9]{0,3}$";

var re = new RegExp(regu);

if (re.test(s)) {

return true;

} else {

return false;

}

}

/*

用途:檢查輸入字符串是否只由英文字母和數字和下劃線組成

輸入:

s:字符串

返回:

若是經過驗證返回true,不然返回false

*/

function isNumberOr_Letter( s ){//判斷是不是數字或字母

var regu = "^[0-9a-zA-Z\_]+$";

var re = new RegExp(regu);

if (re.test(s)) {

return true;

}else{

return false;

}

}

/*

用途:檢查輸入字符串是否只由英文字母和數字組成

輸入:

s:字符串

返回:

若是經過驗證返回true,不然返回false

*/

function isNumberOrLetter( s ){//判斷是不是數字或字母

var regu = "^[0-9a-zA-Z]+$";

var re = new RegExp(regu);

if (re.test(s)) {

return true;

}else{

return false;

}

}

/*

用途:檢查輸入字符串是否只由漢字、字母、數字組成

輸入:

value:字符串

返回:

若是經過驗證返回true,不然返回false

*/

function isChinaOrNumbOrLett( s ){//判斷是不是漢字、字母、數字組成

var regu = "^[0-9a-zA-Z\u4e00-\u9fa5]+$";  

var re = new RegExp(regu);

if (re.test(s)) {

return true;

}else{

return false;

}

}

/*

用途:判斷是不是日期

輸入:date:日期;fmt:日期格式

返回:若是經過驗證返回true,不然返回false

*/

function isDate( date, fmt ) {

if (fmt==null) fmt="yyyyMMdd";

var yIndex = fmt.indexOf("yyyy");

if(yIndex==-1) return false;

var year = date.substring(yIndex,yIndex+4);

var mIndex = fmt.indexOf("MM");

if(mIndex==-1) return false;

var month = date.substring(mIndex,mIndex+2);

var dIndex = fmt.indexOf("dd");

if(dIndex==-1) return false;

var day = date.substring(dIndex,dIndex+2);

if(!isNumber(year)||year>"2100" || year< "1900") return false;

if(!isNumber(month)||month>"12" || month< "01") return false;

if(day>getMaxDay(year,month) || day< "01") return false;

return true;

}

function getMaxDay(year,month) {

if(month==4||month==6||month==9||month==11)

return "30";

if(month==2)

if(year%4==0&&year%100!=0 || year%400==0)

return "29";

else

return "28";

return "31";

}

/*

用途:字符1是否以字符串2結束

輸入:str1:字符串;str2:被包含的字符串

返回:若是經過驗證返回true,不然返回false

*/

function isLastMatch(str1,str2)

var index = str1.lastIndexOf(str2);

if(str1.length==index+str2.length) return true;

return false;

}

 

/*

用途:字符1是否以字符串2開始

輸入:str1:字符串;str2:被包含的字符串

返回:若是經過驗證返回true,不然返回false

*/

function isFirstMatch(str1,str2)

var index = str1.indexOf(str2);

if(index==0) return true;

return false;

}

/*

用途:字符1是包含字符串2

輸入:str1:字符串;str2:被包含的字符串

返回:若是經過驗證返回true,不然返回false

*/

function isMatch(str1,str2)

var index = str1.indexOf(str2);

if(index==-1) return false;

return true;

}

 

/*

用途:檢查輸入的起止日期是否正確,規則爲兩個日期的格式正確,

且結束如期>=起始日期

輸入:

startDate:起始日期,字符串

endDate:結束如期,字符串

返回:

若是經過驗證返回true,不然返回false

*/

function checkTwoDate( startDate,endDate ) {

if( !isDate(startDate) ) {

alert("起始日期不正確!");

return false;

} else if( !isDate(endDate) ) {

alert("終止日期不正確!");

return false;

} else if( startDate > endDate ) {

alert("起始日期不能大於終止日期!");

return false;

}

return true;

}

/*

用途:檢查輸入的Email信箱格式是否正確

輸入:

strEmail:字符串

返回:

若是經過驗證返回true,不然返回false

*/

function checkEmail(strEmail) {

//var emailReg = /^[_a-z0-9]+@([_a-z0-9]+\.)+[a-z0-9]{2,3}$/;

var emailReg = /^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/;

if( emailReg.test(strEmail) ){

return true;

}else{

alert("您輸入的Email地址格式不正確!");

return false;

}

}

/*

用途:檢查輸入的電話號碼格式是否正確

輸入:

strPhone:字符串

返回:

若是經過驗證返回true,不然返回false

*/

function checkPhone( strPhone ) {

var phoneRegWithArea = /^[0][1-9]{2,3}-[0-9]{5,10}$/;

var phoneRegNoArea = /^[1-9]{1}[0-9]{5,8}$/;

var prompt = "您輸入的電話號碼不正確!"

if( strPhone.length > 9 ) {

if( phoneRegWithArea.test(strPhone) ){

return true;

}else{

alert( prompt );

return false;

}

}else{

if( phoneRegNoArea.test( strPhone ) ){

return true;

}else{

alert( prompt );

return false;

}

 

}

}

 

/*

用途:檢查複選框被選中的數目

輸入:

checkboxID:字符串

返回:

返回該複選框中被選中的數目

*/

function checkSelect( checkboxID ) {

var check = 0;

var i=0;

if( document.all(checkboxID).length > 0 ) {

for(  i=0; i<document.all(checkboxID).length; i++ ) {

if( document.all(checkboxID).item( i ).checked  ) {

check += 1;

}

 

 

}

}else{

if( document.all(checkboxID).checked )

check = 1;

}

return check;

}

function getTotalBytes(varField) {

if(varField == null)

return -1;

var totalCount = 0;

for (i = 0; i< varField.value.length; i++) {

if (varField.value.charCodeAt(i) > 127)

totalCount += 2;

else

totalCount++ ;

}

return totalCount;

}

function getFirstSelectedValue( checkboxID ){

var value = null;

var i=0;

if( document.all(checkboxID).length > 0 ){

for(  i=0; i<document.all(checkboxID).length; i++ ){

if( document.all(checkboxID).item( i ).checked ){

value = document.all(checkboxID).item(i).value;

break;

}

}

} else {

if( document.all(checkboxID).checked )

value = document.all(checkboxID).value;

}

return value;

}

 

function getFirstSelectedIndex( checkboxID ){

var value = -2;

var i=0;

if( document.all(checkboxID).length > 0 ){

for(  i=0; i<document.all(checkboxID).length; i++ ) {

if( document.all(checkboxID).item( i ).checked  ) {

value = i;

break;

}

}

} else {

if( document.all(checkboxID).checked )

value = -1;

}

return value;

}

function selectAll( checkboxID,status ){

if( document.all(checkboxID) == null)

return;

if( document.all(checkboxID).length > 0 ){

for(  i=0; i<document.all(checkboxID).length; i++ ){

document.all(checkboxID).item( i ).checked = status;

}

} else {

document.all(checkboxID).checked = status;

}

}

function selectInverse( checkboxID ) {

if( document.all(checkboxID) == null)

return;

if( document.all(checkboxID).length > 0 ) {

for(  i=0; i<document.all(checkboxID).length; i++ ) {

document.all(checkboxID).item( i ).checked = !document.all(checkboxID).item( i ).checked;

}

} else {

document.all(checkboxID).checked = !document.all(checkboxID).checked;

}

}

function checkDate( value ) {

if(value=='') return true;

if(value.length!=8 || !isNumber(value)) return false; 

var year = value.substring(0,4);

if(year>"2100" || year< "1900")

return false;

var month = value.substring(4,6);

if(month>"12" || month< "01") return false;

var day = value.substring(6,8);

if(day>getMaxDay(year,month) || day< "01") return false;

return true; 

}

/*

用途:檢查輸入的起止日期是否正確,規則爲兩個日期的格式正確或都爲空

且結束日期>=起始日期

輸入:

startDate:起始日期,字符串

endDate:  結束日期,字符串

返回:

若是經過驗證返回true,不然返回false

*/

function checkPeriod( startDate,endDate ) {

if( !checkDate(startDate) ) {

alert("起始日期不正確!");

return false;

} else if( !checkDate(endDate) ) {

alert("終止日期不正確!");

return false;

} else if( startDate > endDate ) {

alert("起始日期不能大於終止日期!");

return false;

}

return true;

}

/*

用途:檢查證券代碼是否正確

輸入:

secCode:證券代碼

返回:

若是經過驗證返回true,不然返回false

*/

function checkSecCode( secCode ) {

if( secCode.length !=6 ){

alert("證券代碼長度應該爲6位");

return false;

}

if(!isNumber( secCode ) ){

alert("證券代碼只能包含數字");

 

return false;

}

return true;

}

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

function:cTrim(sInputString,iType)

description:字符串去空格的函數

parameters:iType:1=去掉字符串左邊的空格

2=去掉字符串左邊的空格

0=去掉字符串左邊和右邊的空格

return value:去掉空格的字符串

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

function cTrim(sInputString,iType)

{

var sTmpStr = ' ';

var i = -1;

if(iType == 0 || iType == 1)

{

while(sTmpStr == ' ')

{

++i;

sTmpStr = sInputString.substr(i,1);

}

sInputString = sInputString.substring(i);

}

if(iType == 0 || iType == 2)

{

sTmpStr = ' ';

i = sInputString.length;

while(sTmpStr == ' ')

{

--i;

sTmpStr = sInputString.substr(i,1);

}

sInputString = sInputString.substring(0,i+1);

}

return sInputString;

}

/*

JavaScript腳本,驗證表單中的數據項  begin 

------------------------------------------------------------------------------- 

*/ 

function checkForm(objFrm){ 

var len = 0; 

len = objFrm.elements.length; 

var i = 0; 

var objCheck; 

//文本框 

for(i = 0; i < len; i ++){ 

objCheck = objFrm.elements[i]; 

if(objCheck.type =="text" && !f_checkTextValid(objCheck) ){ 

return false; 

//下拉框 

for(i = 0; i < len; i ++){ 

objCheck = objFrm.elements[i]; 

if(objCheck.type =="select-one" && !f_checkSelectValid(objCheck) ){ 

return false; 

//時間段有效 

if( f_checkStartAndEndDate(objFrm) == false) return false; 

return true; 

function f_checkSelectValid(obj){ 

//alert("check select"); 

if(obj.options.length <= 0){ 

alert("下拉選框無數據!"); 

return false; 

return true; 

function f_checkStartAndEndDate(frm){ 

var len = frm.elements.length; 

if(len == null && len == 0) return true; 

var i=0; 

var temp; 

var objCheck; 

var objStartDate; 

var objEndDate; 

//alert("start date period check"); 

try{ 

for(i=0; i< len ; i++){ 

objCheck = frm.elements[i]; 

temp = objCheck.name; 

if( temp.indexOf("startDate") >0 ||temp.indexOf("beginDate")>0 ) 

objStartDate = objCheck; 

if( temp.indexOf("endDate") > 0 ) 

objEndDate = objCheck; 

//alert(objStartDate.value); 

//alert(objEndDate.value); 

if(objStartDate.value==null || objStartDate.value =="" || objStartDate.value ==null || objStartDate.value ==""){ 

return true; 

return checkTwoDate(objStartDate.value, objEndDate.value); 

//alert("end date period check"); 

}catch(E){} 

return true; 

function f_checkTextValid(obj){ 

//不能爲空 

if(obj.getAttribute("isNeed") != null){ 

if(f_isNotNull(obj) == false) return false; 

//不能超過長度 

if(obj.getAttribute("maxlength") != null){ 

if(f_checkLength(obj) == false) return false; 

var checkType =""; 

checkType = obj.getAttribute("checkType"); 

if(checkType==null||checkType=="") return true; 

// 

if (checkType.indexOf("number") >=0){ 

if(f_isNumber(obj) == false)  return false; 

if(f_checkNumType(obj,checkType) == false)  return false; 

// 

if (checkType.indexOf("positive") >=0){ 

if(f_isNumber(obj) == false)  return false; 

if(f_isPositive(obj)==false)  return false; 

if(f_checkNumType(obj,checkType) == false)  return false; 

if (checkType.indexOf("date") >=0){ 

if(f_checkDate(obj) == false) return false; 

/* 

switch(checkType){ 

case "number": if(f_isNumber(obj) == false) return false;break; 

case "date": if(f_checkDate(obj) == false) return false;break; 

default: 

*/ 

return true; 

function f_isNotNull(obj){ 

if(obj.value == ""){ 

f_alert(obj, " 不容許爲空值!"); 

return false; 

return true; 

function f_isNumber(obj){ 

if(isNaN(obj.value)){ 

f_alert(obj," 應爲數值類型"); 

return false; 

return true; 

function f_checkDate(obj) { 

if(checkDate(obj.value) ==false){ 

f_alert(obj," 不是合法日期格式!"); 

return false; 

return true; 

function f_checkLength(obj){ 

if(getTotalBytes(obj) > Math.abs( obj.getAttribute("maxlength") ) ){ 

f_alert(obj," 超出長度限制!"); 

return false; 

return true; 

function  f_alert(obj,alertStr){ 

var fielName = obj.getAttribute("fieldName"); 

if(fielName == null) 

fielName = ""; 

alert(fielName + "\n" +alertStr); 

obj.select(); 

obj.focus(); 

function f_checkNumType(obj, numType){ 

//假設: 已經進行數字類型判斷 

var strTemp; 

var numpric; 

var numLen; 

var strArr; 

var defaultLen = 19; 

var defaultpric = 5; 

try{ 

if(numType == null|| numType =="") return f_checkNumLenPrec(obj,defaultLen, defaultpric); 

if(numType.indexOf("(") < 0 || numType.indexOf(")") < 0 ) return f_checkNumLenPrec(obj,defaultLen, defaultpric); 

strTemp = numType.substr( numType.indexOf("(") + 1 ,numType.indexOf(")") - numType.indexOf("(") -1 ); 

if(strTemp == null||strTemp =="") return f_checkNumLenPrec(obj,defaultLen, defaultpric); 

strArr = strTemp.split(","); 

numLen = Math.abs( strArr[0] ); 

numpric = Math.abs( strArr[1] ); 

return f_checkNumLenPrec(obj,numLen, numpric); 

}catch(e){ 

alert("in f_checkNumType = " + e); 

return f_checkNumLenPrec(obj,defaultLen, defaultpric); 

function f_checkNumLenPrec(obj, len, pric){ 

var numReg; 

var value = obj.value; 

var strValueTemp, strInt, strDec; 

//alert(value + "=====" + len + "====="+ pric); 

try{ 

numReg =/[\-]/; 

strValueTemp = value.replace(numReg, ""); 

strValueTemp = strValueTemp.replace(numReg, ""); 

//整數 

if(pric==0){ 

numReg =/[\.]/; 

//alert(numReg.test(value)); 

if(numReg.test(value) == true){ 

f_alert(obj, "輸入必須爲整數類型!"); 

return false; 

if(strValueTemp.indexOf(".") < 0 ){ 

//alert("lennth==" + strValueTemp); 

if(strValueTemp.length >( len - pric)){ 

f_alert(obj, "整數位不能超過"+ (len - pric) +"位"); 

return false; 

}else{ 

strInt = strValueTemp.substr( 0, strValueTemp.indexOf(".") ); 

//alert("lennth==" + strInt); 

if(strInt.length >( len - pric)){ 

f_alert(obj, "整數位不能超過"+ (len - pric) +"位"); 

return false; 

strDec = strValueTemp.substr( (strValueTemp.indexOf(".")+1), strValueTemp.length ); 

//alert("pric==" + strDec); 

if(strDec.length > pric){ 

f_alert(obj, "小數位不能超過"+  pric +"位"); 

return false; 

return true; 

}catch(e){ 

alert("in f_checkNumLenPrec = " + e); 

return false; 

function f_isPositive(obj){ 

var numReg =/[\-]/; 

if(numReg.test(obj.value) == true){ 

f_alert(obj, "必須爲正數!"); 

return false; 

return true; 

/* 

function selectedCheckboxCount(form) 

功能說明:對Form中選中的可選項計數 

參數說明: 

form:指定的表單 

*/ 

function selectedCheckboxCount(form){ 

var length =0; 

var i=0; 

var count =0; 

eles = form.elements; 

while(i<eles.length){ 

obj= eles.item(i); 

//type = obj.attributes.item("type").nodeValue; 

type = obj.type; 

if(type == "checkbox"){ 

if(obj.checked){ 

count++; 

i++; 

return count; 

//獲得字節長度 

function getByteLen(str) 

var l = str.length; 

var n = l; 

for ( var i=0; i<l; i++ ) 

if ( str.charCodeAt(i) <0 || str.charCodeAt(i) >255 ) 

n=n+1; 

return n 

/* 

說明: 

1.清除表格中的數據(0.0 和 0) 

2.若是cell中沒有數據,則自動加上一個空格 

3.清除空白行的checkbox 

參數: 

clearzero:是否清除"0"、"0.0",false不清除、true清除(默認爲true) 

tablename:要清除的表格名字,默認爲sortTable 

*/ 

function clear_table(clearzero,tablename) 

var tobject; 

if(tablename==null) 

tobject=gmobj("sortTable"); 

else 

tobject=gmobj(tablename); 

//若是table未定義,則不進行過濾 

if(tobject==null) 

return; 

//若是函數調用參數爲空,表示要清除0、0.0;反之,不要清除0、0.0。 

var clear = (clearzero==null)?true:clearzero; 

//清除0、0.0,填補空格 

var rows = tobject.rows; 

var j=0; 

for(var i=0;i<rows.length;i++) 

//取得第一個cell的屬性clear,若是爲1,表示該行沒有數據,則清除該行全部數據 

while(tobject.rows[i].cells[j] != null) 

if(clear) 

if(tobject.rows[i].cells[j].innerHTML==0 ||tobject.rows[i].cells[j].innerHTML==0.0||tobject.rows[i].cells[j].innerHTML=="") 

tobject.rows[i].cells[j].innerText=" "; 

else 

if (tobject.rows[i].cells[j].innerHTML=="") 

tobject.rows[i].cells[j].innerText=" "; 

j++; 

j=0; 

return true; 

function gmobj(mtxt)  /* Get object by object name */ 

if (document.getElementById) { 

m=document.getElementById(mtxt); 

} else if (document.all) { 

m=document.all[mtxt]; 

} else if (document.layers) { 

m=document.layers[mtxt]; 

return m; 

/* 

------------------------------------------------------------------------------- 

說明:JavaScript腳本,驗證表單中的數據項  end 

------------------------------------------------------------------------------- 

*/ 

/* 

用途:檢查輸入字符串是不是帶小數的數字格式,能夠是負數(而且知足規定的精度) 

輸入:str:字符串 

l:總位數 

d:小數點後位數 

返回: 

若是經過驗證返回true,不然返回false 

*/ 

function isDecimal( str,l,d ){   

if(isInteger(str)) { 

if (l==null)  return true; 

if (str<0) l--; 

if (str.length<=l) return true; 

var re = /^[-]{0,1}(\d+)[\.]+(\d+)$/; 

if (re.test(str)) { 

if (l==null)  return true; 

if (d==null) d=0; 

if(RegExp.$1==0&&RegExp.$2==0) return false; 

if (RegExp.$1.length+RegExp.$2.length<=l 

&& RegExp.$2.length<=d)  return true; 

return false; 

onclick="isNull('Co.PageForm.CompetitorName');" 

Co--指本頁面   PageForm--指formName  CompetitorName---指的是文本欄名 

相關文章
相關標籤/搜索