类型识别

  • typeof
  • Object.prototype.toString
  • constructor
  • instanceof

typeof

  • 可以是标准类型(Null 除外)
  • 不可识别具体的对象类型(Function 除外)

Object.prototype.toString

  • 可是识别标准类型及内置对象类型(例如,Object, Date, Array)
  • 不能识别自定义对象类型

constructor

  • 可以识别标准类型(Undefined/Null 除外)
  • 可识别内置对象类型
  • 可识别自定义对象类型
  1. function getConstructiorName(obj) {
  2. return obj && obj.constructor && obj.constructor.toString().match(/function\s*([^(]*)/)[1];
  3. }
  4. getConstructiorName([]) === "Array"; // true

instanceof

  • 不可判别原始类型
  • 可判别内置对象类型
  • 可判别自定义对象类型

JavaScript的数据类型可以分为:标准类型和对象类型。

标准类型有:undefined Null Boolean Date Number Object

对象类型(构造器类型):Boolean Date Number Object Array Date Error Function RegExp

用来判断数据类型的一般有四种方式,分别是:

  • typeof
  • Prototype.toString()
  • constructor
  • instanceof

下面我们写一个HTML来检验一下:

  1. <html>
  2. <head>
  3. <title>JavaScript类型判断</title>
  4. <meta charset="utf-8">
  5. <style type="text/css">
  6. .red{
  7. background-color:red;
  8. }
  9. </style>
  10. </head>
  11. <body>
  12. <script type="text/javascript">
  13. /* Standard Type */
  14. var a; //undefined
  15. var b = document.getElementById("no_exist_element"); //null
  16. var c = true; //Boolean
  17. var d = 1; //Number
  18. var e = "str"; //String
  19. var f = {name : "Tom"}; //Object
  20. /* Object Type */
  21. var g = new Boolean(true); //Boolean Object
  22. var h = new Number(1); //Number Object
  23. var i = new String("str"); //String Object
  24. var j = new Object({name : "Tom"}); //Object Object
  25. var k = new Array([1, 2, 3, 4]); //Array Object
  26. var l = new Date(); //Date Object
  27. var m = new Error();
  28. var n = new Function();
  29. var o = new RegExp("\\d");
  30. /* Self-Defined Object Type */
  31. function Point(x, y) {
  32. this.x = x;
  33. this.y = y;
  34. }
  35. Point.prototype.move = function(x, y) {
  36. this.x += x;
  37. this.y += y;
  38. }
  39. var p = new Point(1, 2);
  40. /* Use the Prototype.toString() to judge the type */
  41. function type(obj){
  42. return Object.prototype.toString.call(obj).slice(8, -1).toLowerCase();
  43. }
  44. </script>
  45. <table border="1" cellspacing="0">
  46. <tr>
  47. <td></td>
  48. <td>typeof</td>
  49. <td>toString</td>
  50. <td>constructor</td>
  51. <td>instanceof</td>
  52. </tr>
  53. <tr>
  54. <td>undefined</td>
  55. <td><script type="text/javascript">document.write(typeof a)</script></td>
  56. <td><script type="text/javascript">document.write(type(a))</script></td>
  57. <td class="red"><script type="text/javascript">document.write(a.constructor)</script></td>
  58. <td class="red"><script type="text/javascript">document.write(a instanceof "undefined")</script></td>
  59. </tr>
  60. <tr>
  61. <td>Null</td>
  62. <td class="red"><script type="text/javascript">document.write(typeof b);</script></td>
  63. <td><script type="text/javascript">document.write(type(b));</script></td>
  64. <td class="red"><script type="text/javascript">document.write(b.constructor);</script></td>
  65. <td class="red"><script type="text/javascript">document.write(b instanceof "null");</script></td>
  66. </tr>
  67. <tr>
  68. <td>Boolean</td>
  69. <td><script type="text/javascript">document.write(typeof c);</script></td>
  70. <td><script type="text/javascript">document.write(type(c));</script></td>
  71. <td><script type="text/javascript">document.write(c.constructor);</script></td>
  72. <td class="red"><script type="text/javascript">document.write(c instanceof "boolean");</script></td>
  73. </tr>
  74. <tr>
  75. <td>Number</td>
  76. <td><script type="text/javascript">document.write(typeof d);</script></td>
  77. <td><script type="text/javascript">document.write(type(d));</script></td>
  78. <td><script type="text/javascript">document.write(d.constructor);</script></td>
  79. <td class="red"><script type="text/javascript">document.write(d instanceof "number");</script></td>
  80. </tr>
  81. <tr>
  82. <td>String</td>
  83. <td><script type="text/javascript">document.write(typeof e);</script></td>
  84. <td><script type="text/javascript">document.write(type(e));</script></td>
  85. <td><script type="text/javascript">document.write(e.constructor);</script></td>
  86. <td class="red"><script type="text/javascript">document.write(e instanceof "string");</script></td>
  87. </tr>
  88. <tr>
  89. <td>Object</td>
  90. <td><script type="text/javascript">document.write(typeof f);</script></td>
  91. <td><script type="text/javascript">document.write(type(f));</script></td>
  92. <td><script type="text/javascript">document.write(f.constructor);</script></td>
  93. <td class="red"><script type="text/javascript">document.write(f instanceof "object");</script></td>
  94. </tr>
  95. <tr><td colspan="5">-----------------------</td></tr>
  96. <tr>
  97. <td>Boolean Object</td>
  98. <td class="red"><script type="text/javascript">document.write(typeof g);</script></td>
  99. <td><script type="text/javascript">document.write(type(g));</script></td>
  100. <td><script type="text/javascript">document.write(g.constructor);</script></td>
  101. <td><script type="text/javascript">document.write(g instanceof Boolean);</script></td>
  102. </tr>
  103. <tr>
  104. <td>Number Object</td>
  105. <td class="red"><script type="text/javascript">document.write(typeof h);</script></td>
  106. <td><script type="text/javascript">document.write(type(h));</script></td>
  107. <td><script type="text/javascript">document.write(h.constructor);</script></td>
  108. <td><script type="text/javascript">document.write(h instanceof Number);</script></td>
  109. </tr>
  110. <tr>
  111. <td>String Object</td>
  112. <td class="red"><script type="text/javascript">document.write(typeof i);</script></td>
  113. <td><script type="text/javascript">document.write(type(i));</script></td>
  114. <td><script type="text/javascript">document.write(i.constructor);</script></td>
  115. <td><script type="text/javascript">document.write(i instanceof String);</script></td>
  116. </tr>
  117. <tr>
  118. <td>Object Object</td>
  119. <td class="red"><script type="text/javascript">document.write(typeof j);</script></td>
  120. <td><script type="text/javascript">document.write(type(j));</script></td>
  121. <td><script type="text/javascript">document.write(j.constructor);</script></td>
  122. <td><script type="text/javascript">document.write(j instanceof Object);</script></td>
  123. </tr>
  124. <tr>
  125. <td>Array Object</td>
  126. <td class="red"><script type="text/javascript">document.write(typeof k);</script></td>
  127. <td><script type="text/javascript">document.write(type(k));</script></td>
  128. <td><script type="text/javascript">document.write(k.constructor);</script></td>
  129. <td><script type="text/javascript">document.write(k instanceof Array);</script></td>
  130. </tr>
  131. <tr>
  132. <td>Date Object</td>
  133. <td class="red"><script type="text/javascript">document.write(typeof l);</script></td>
  134. <td><script type="text/javascript">document.write(type(l));</script></td>
  135. <td><script type="text/javascript">document.write(l.constructor);</script></td>
  136. <td><script type="text/javascript">document.write(l instanceof Date);</script></td>
  137. </tr>
  138. <tr>
  139. <td>Error Object</td>
  140. <td class="red"><script type="text/javascript">document.write(typeof m);</script></td>
  141. <td><script type="text/javascript">document.write(type(m));</script></td>
  142. <td><script type="text/javascript">document.write(m.constructor);</script></td>
  143. <td><script type="text/javascript">document.write(m instanceof Error);</script></td>
  144. </tr>
  145. <tr>
  146. <td>Function Object</td>
  147. <td><script type="text/javascript">document.write(typeof n);</script></td>
  148. <td><script type="text/javascript">document.write(type(n));</script></td>
  149. <td><script type="text/javascript">document.write(n.constructor);</script></td>
  150. <td><script type="text/javascript">document.write(n instanceof Function);</script></td>
  151. </tr>
  152. <tr>
  153. <td>RegExp Object</td>
  154. <td class="red"><script type="text/javascript">document.write(typeof o);</script></td>
  155. <td><script type="text/javascript">document.write(type(o));</script></td>
  156. <td><script type="text/javascript">document.write(o.constructor);</script></td>
  157. <td><script type="text/javascript">document.write(o instanceof RegExp);</script></td>
  158. </tr>
  159. <tr><td colspan="5">-----------------------</td></tr>
  160. <tr>
  161. <td>Point Objct</td>
  162. <td class="red"><script type="text/javascript">document.write(typeof p);</script></td>
  163. <td class="red"><script type="text/javascript">document.write(type(p));</script></td>
  164. <td><script type="text/javascript">document.write(p.constructor);</script></td>
  165. <td><script type="text/javascript">document.write(p instanceof Point);</script></td>
  166. </tr>
  167. </table>
  168. </body>
  169. </html>

执行的结果如下:

类型判断 - 图1

其中红色的单元格表示该判断方式不支持的类型。