typeof操作符用于检测数据类型,返回字符串表示;其可识别number、string、boolean、undefined、object、function、symbol和bigint;但需注意null返回"object"为历史bug,数组和对象均返回"object"无法区分,应结合Array.isArray()等方法判断;对未声明变量使用typeof不报错,返回"undefined";适用于快速判断原始类型,如检查变量是否定义或值是否为函数。

typeof 是 JavaScript 中的一个一元操作符,用于检测变量或表达式的数据类型,并返回一个表示该类型名称的字符串。
基本用法
使用 typeof 时,它会返回以下几种字符串之一,表示对应的数据类型:- "number" —— 数值类型(包括 NaN)
- "string" —— 字符串类型
- "boolean" —— 布尔类型(true 或 false)
- "undefined" —— 未定义类型
- "object" —— 对象、数组、null 的类型(注意:null 返回 "object" 是历史遗留问题)
- "function" —— 函数类型
- "symbol" —— Symbol 类型(ES6 新增)
- "bigint" —— 大整数类型(ES2020 新增)
示例:
采用HttpClient向服务器端action请求数据,当然调用服务器端方法获取数据并不止这一种。WebService也可以为我们提供所需数据,那么什么是webService呢?,它是一种基于SAOP协议的远程调用标准,通过webservice可以将不同操作系统平台,不同语言,不同技术整合到一起。 实现Android与服务器端数据交互,我们在PC机器java客户端中,需要一些库,比如XFire,Axis2,CXF等等来支持访问WebService,但是这些库并不适合我们资源有限的android手机客户端,
console.log(typeof 'hello'); // "string"
console.log(typeof true); // "boolean"
console.log(typeof undefined); // "undefined"
console.log(typeof null); // "object" (注意!)
console.log(typeof []); // "object"
console.log(typeof {}); // "object"
console.log(typeof function(){}); // "function"
常见注意事项
typeof 虽然简单实用,但有几点需要特别注意:- null 的类型被错误地识别为 "object",这是 JavaScript 的早期 bug,一直保留至今。判断 null 应使用严格等于:value === null
- 数组也是对象,typeof 无法区分普通对象和数组。要判断数组应使用 Array.isArray()
- 不能区分不同类型的对象,比如 Date、RegExp 都返回 "object"
- 对未声明的变量使用 typeof 不会报错,返回 "undefined"
适用场景
typeof 最适合用于快速判断原始类型(primitive types):- 检查变量是否已定义:typeof variable !== 'undefined'
- 确保某个值是函数再调用:if (typeof cb === 'function') cb()
- 防止对非字符串进行字符串操作
基本上就这些。typeof 简单直接,但在处理复杂类型时需配合其他方法使用才更准确。









