DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> js驗證是否為數字的總結
js驗證是否為數字的總結
編輯:關於JavaScript     

js驗證是否為數字,最簡單的方法:

isNaN函數的使用:

function checknum() {
  if (isNaN(frm.num.value)) {
    alert("請輸入數字");
    frm.num.focus();

    return false;
  }
}

最完整最精確的方法:(正則表達式)

1)

   "^\\d+$"          //非負整數(正整數 + 0)
  "^[0-9]*[1-9][0-9]*$"    //正整數
  "^((-\\d+)|(0+))$"        //非正整數(負整數 + 0)
  "^-[0-9]*[1-9][0-9]*$"    //負整數
  "^-?\\d+$"           //整數
  "^\\d+("           //非負浮點數(正浮點數 + 0)
  "^(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*))$"    //正浮點數
  "^((-\\d+("           //非正浮點數(負浮點數 + 0)
  "^(-(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*)))$"    //負浮點數
  "^(-?\\d+)("         //浮點數
2)

  var r = /^\+?[1-9][0-9]*$/;  //正整數
      r.test(str);

最直觀的方法:

<script language="javascript">
  function CheckMyForm() {
    var txt = myform.mytext.value;
    if(checknumber(txt)) {
      alert("只允許輸入數字!");
      return false;
    }
    return true;
  }

  function checknumber(String) {
    var Letters = "1234567890";
    var i;
    var c;
    for( i = 0; i < Letters.length(); i ++ )   {   //Letters.length() ->>>>取字符長度
      c = Letters.charAt( i );
      if (Letters.indexOf( c ) ==-1)   { //在"Letters"中找不到"c"   見下面的此函數的返回值
        return true;
        }
    }
    return false;
  }
</script>

拓展:=====================================

charAt  

charAt(int index)方法是一個能夠用來檢索特定引索下的字符的String實例的方法.
  charAt()方法返回一個位於提供給它的參數引索處的字符.
  如: str.chatAt(0)檢索str中的第一個字符,str.charAt(str.length()-1)檢索最後一個字符.
  下面的示例闡釋了 charAt 方法的用法:
  <script language="javascript">
    function charAtTest(n){
      var str = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";// Initialize variable.
      var s; // Declare variable.
      s = str.charAt(n - 1); // Get correct character // from position n – 1.
      return(s); // Return character.
    }
    alert(3);

  </script>

IndexOf

String.IndexOf 方法 (value, [startIndex], [count]):
  用法和 indexof() 完全相同。

  報告指定字符在此實例中的第一個匹配項的索引。搜索從指定字符位置開始,並檢查指定數量的字符位置。

  參數

  value

  要查找的 Unicode 字符。 對 value 的搜索區分大小寫。

  startIndex(Int32)

  可選項,搜索起始位置。不設置則從0開始。

  count(Int32)

  可選項,要檢查的字符位置數。

  返回值

  如果找到該字符,則為 value 的索引位置;否則如果未找到,則為 -1。

  IndexOf()

  查找字串中指定字符或字串首次出現的位置,返首索引值,如:

  str1.IndexOf("字"); //查找“字”在str1中的索引值(位置)

  str1.IndexOf("字串");//查找“字串”的第一個字符在str1中的索引值(位置)

  str1.IndexOf("字",start,end);//從str1第start+1個字符起,查找end個字符,查找“字”在字符串STR1中的位置[從第一個字符算起]注意:start+end不能大於str1的長度

  indexof參數為string,在字符串中尋找參數字符串第一次出現的位置並返回該位置。如string s="0123dfdfdf";int i=s.indexof("df");這時i==4。

  如果需要更強大的字符串解析功能應該用Regex類,使用正則表達式對字符串進行匹配。

  [轉貼]原信息URL:http://www.jb51.net/html/blog/1/23464.htm

  indexof() :在字符串中從前向後定位字符和字符串;所有的返回值都是指在字符串的絕對位置,如為空則為- 1

  string test="asdfjsdfjgkfasdsfsgfhgjgfjgdddd";

  test.indexof('d') =2 //從前向後 定位 d 第一次出現的位置

  test.indexof('d',1) =2 //從前向後 定位 d 從第三個字符串 第一次出現的位置

  test.indexof('d',5,2) =6 //從前向後 定位 d 從第5 位開始查,查2位,即 從第5位到第7位;

  lastindexof() :在字符串中從後向前定位字符和字符串;

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved