javascript資料類型驗證方法,javascript資料類型

來源:互聯網
上載者:User

javascript資料類型驗證方法,javascript資料類型

最近對javascript資料類型的驗證又有了一個新的認識,原來可以判斷得這麼簡單又如此全面。
我們自訂了isString,isNumber ,isDate ,isError ,isRegExp ,isBoolean ,isNull ,isUndefined ,isObject等方法。現在將自己定義的javascript資料類型驗證函式及測試集展示:

<!DOCTYPE html> <html>   <head>     <meta charset="utf-8">     <title></title>   </head>   <body>        </body> <script type="text/javascript"> //isString //isNumber //isDate //isError //isRegExp //直接利用和資料類型來判斷 [].forEach.call(['String','Number','Date','Error','RegExp'],function(name){   this['is'+name]=function(obj){     return toString.call(obj)==='[object '+name+']';   }; }); //isBoolean //true和false需要考慮在內 Object.prototype.isBoolean=function(obj){   return obj===true||obj===false||toString.call(obj)==='[object Boolean]'; }; //isNull //未找到所指向對象 Object.prototype.isNull=function(obj){   return obj===null; }; //isUndefined //定義了但是未賦值 Object.prototype.isUndefined=function(obj){   return obj===void 0; }; //isObject //函數和數組都是對象 Object.prototype.isObject=function(obj){   var type = typeof obj;   return type === 'function' || type === 'object' && !!obj; };  //test //isString var str="iamstring"; var a=isString(str); console.log(a);//true  //isNumber var b=isNumber(a); console.log(b);//false  //isNumber var num=4; var c=isNumber(num); console.log(c);//true  //isRegExp var reg=/^[1-9]/; var d=isRegExp(reg); console.log(d);//true  //isDate var date=new Date(); var e=isDate(date); console.log(e);//true  //isBoolean var bool=false; var f=isBoolean(bool); console.log(f);//true  //isNull var nul=document.getElementById("div02"); var g=isNull(nul); console.log(g);//true  //isUndefined var undef; var h=isUndefined(undef); console.log(h);//true  //isObject var obj={"1":"1","2":"2"}; var i=isObject(obj); console.log(i);//true  </script> </html> 

以下主要是對判斷javascript的資料類型進行了詳細的介紹,分為六種資料類型,需要的朋友可以過來參考下,希望對大家有所協助
1、判斷是否為數群組類型
代碼如下:

<STRONG><script type="text/javascript"> //<![CDATA[ var a=[0]; document.write(isArray(a),'<br/>'); function isArray(obj){ return (typeof obj=='object')&&obj.constructor==Array; } //]]> </script></STRONG>

2 判斷是否為字串類型
代碼如下:

<script type="text/javascript"> //<![CDATA[ document.write(isString('test'),'<br/>'); document.write(isString(10),'<br/>'); function isString(str){ return (typeof str=='string')&&str.constructor==String; } //]]> </script>

3 判斷是否為數實值型別
代碼如下:

<script type="text/javascript"> //<![CDATA[ document.write(isNumber('test'),'<br/>'); document.write(isNumber(10),'<br/>'); function isNumber(obj){ return (typeof obj=='number')&&obj.constructor==Number; } //]]> </script>

4 判斷是否為日期類型
代碼如下:

<script type="text/javascript"> //<![CDATA[ document.write(isDate(new Date()),'<br/>'); document.write(isDate(10),'<br/>'); function isDate(obj){ return (typeof obj=='object')&&obj.constructor==Date; } //]]> </script>

5 判斷是否為函數
代碼如下:

<script type="text/javascript"> //<![CDATA[ document.write(isFunction(function test(){}),'<br/>'); document.write(isFunction(10),'<br/>'); function isFunction(obj){ return (typeof obj=='function')&&obj.constructor==Function; } //]]> </script>

6 判斷是否為對象
代碼如下:

<script type="text/javascript">linenum//<![CDATA[ document.write(isObject(new Object()),'<br/>'); document.write(isObject(10),'<br/>'); function isObject(obj){ return (typeof obj=='object')&&obj.constructor==Object; } //]]> </script>

希望本文所述對大家學習javascript程式設計有所協助。

您可能感興趣的文章:
  • JAVASCRIPT 用戶端驗證資料的合法性代碼(正則)
  • js資料驗證集合、js email驗證、js url驗證、js長度驗證、js數字驗證等簡單封裝
  • asp.net中JavaScript資料驗證實現代碼
  • Javascript級聯下拉式功能表以及AJAX資料驗證核心代碼
  • 如何使用JavaScript和Regex進行資料驗證
  • js Regex 驗證 a/b/c 格式的類型資料

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.