<p>
鉴于 ECMAScript 是松散类型的,因此需要有一种手段来检测给定变量的数据类型——typeof 就是负责提供这方面信息的操作符。对一个值使用 typeof 操作符可能返回下列某个字符串:
</p>
<ul>
<li>
"<code>undefined</code>"——如果这个值未定义;
</li>
<li>
"<code>boolean</code>"——如果这个值是布尔值;
</li>
<li>
"<code>string</code>"——如果这个值是字符串;
</li>
<li>
"<code>number</code>"——如果这个值是数值;
</li>
<li>
"<code>object</code>"——如果这个值是对象或 <code>null</code>;
</li>
<li>
"<code>function</code>"——如果这个值是函数。
</li>
</ul>
<p>
下面是几个使用 typeof 操作符的例子:
</p>
<pre>var message = "some string";
alert(typeof message); // "string"
alert(typeof(message)); // "string"
alert(typeof 95); // "number"</pre>
<a href="http://www.shouce.ren/study/api/s/8349" target="_blank" class="btn btn-sm btn-success">运行一下</a><br />
<p>
这几个例子说明, <code>typeof</code>操作符的操作数可以是变量(<code>message</code>),也可以是数值字面量。注意,<code>typeof</code>是一个操作符而不是函数,因此例子中的圆括号尽管可以使用,但不是必需的。
</p>
<p>
有些时候, <code>typeof</code>操作符会返回一些令人迷惑但技术上却正确的值。比如,调用 <code>typeof null</code>会返回"<code>object</code>",因为特殊值 <code>null</code>被认为是一个空的对象引用。 Safari 5 及之前版本、 Chrome 7 及之前版本在对正则表达式调用 <code>typeof</code>操作符时会返回"<code>function</code>",而其他浏览器在这种情况下会返回"<code>object</code>"。
</p>
<blockquote>
从技术角度讲,函数在 ECMAScript 中是对象,不是一种数据类型。然而,函数也确实有一些特殊的属性,因此通过 typeof 操作符来区分函数和其他对象是有必要的。
</blockquote>