四种Javascript类型检测的方式

开发 前端
今天这篇文章,主要介绍了JavaScript中检测数据类型的4种方式。如果已经会了的可以当成复习,如果还不了解的话,可以认真看看,并加以运用。

一、typeof

主要用于判断基本数据类型 。使用方式:typeof(表达式)和typeof 变量名,第一种是对表达式做运算,第二种是对变量做运算。 typeof运算符的返回类型为字符串,值包括如下几种:

  1. 'undefined':未定义的变量或值
  2. 'boolean':布尔类型的变量或值
  3. 'string' :字符串类型的变量或值
  4. 'number':数字类型的变量或值
  5. 'object' :对象类型的变量或值,或者null(这个是js历史遗留问题,将null作为object类型处理)
  6. 'function' :函数类型的变量或值

示例如下:

console.log(typeof a);    //'undefined'    
console.log(typeof(true)); //'boolean'
console.log(typeof '123'); //'string'
console.log(typeof 123); //'number'
console.log(typeof NaN); //'number'
console.log(typeof null); //'object'
var obj = new String(); console.log(typeof(obj)); //'object'
var fn = function(){}; console.log(typeof(fn)); //'function'
console.log(typeof(class c{})); //'function'

typeof的不足之处:

  1. 不能区分对象、数组、正则,对它们操作都返回"object";(正则特殊一点后面说)
  2. Safar5,Chrome7之前的版本对正则对象返回 'function'
  3. 在IE6,7和8中,大多数的宿主对象是对象,而不是函数;如:typeof alert; //object
  4. 而在非ID浏览器或则IE9以上(包含IE9),typeof alert; //function
  5. 对于null,返回的是object.

总结:

typeof运算符用于判断对象的类型,但是对于一些创建的对象,它们都会返回'object',有时我们需要判断该实例是否为某个对象的实例,那么这个时候需要用到instanceof运算符。

二、instanceof

用于引用数据类型的判断。所有引用数据类型的值都是Object的实例。目的是判断一个对象在其原型链上是否存在构造函数的prototype属性。 用法:

variable instanceof constructor

示例如下:


// example
var arr = [];

由于:
1. arr.constructor === Array
2. arr.__proto__ === Array.prototype
3. arr.__poto__.proto__ === Object.prototype

所以, 以下都返回true
1. arr instanceof arr.constructor(Array)
2. arr instanceof arr.__proto__.constructor(Array)
3. arr instanceof arr.__proto__.__poto__.constructor(Object)


如果你了解原型链的话,你很快就会得出一些结论:
1. 所有对象 instanceof Object 都会返回 true
2. 所有函数 instanceof Function 都会返回 true

总结:

instanceof不仅能检测构造对象的构造器,还检测原型链。instanceof要求前面是个对象,后面是一个构造函数。而且返回的是布尔型的,不是true就是false。

3、Array.isArray()

Array.isArray()可以用于判断数组类型,支持的浏览器有IE9+、FireFox 4+、Safari 5+、Chrome; 兼容实现:

if (!Array.isArray) {
Array.isArray = function(arg) {
return Object.prototype.toString.call(arg) === '[object Array]';
};
}

示例如下:

// 1.
Array.isArray([1, 2, 3, 4]); // --> true

// 2.
var obj = {
a: 1,
b: 2
};
Array.isArray(obj); // --> false

// 3.
Array.isArray(new Array); // --> true

//4.
Array.isArray("Array"); // --> false

总结:

isArray是一个静态方法,使用Array对象(类)调用,而不是数组对象实例。其中Array.prototype 也是一个数组,Array.isArray 优于 instanceof。

四、Object.prototype.toString.call()

判断某个对象值属于哪种内置类型, 最靠谱的做法就是通过Object.prototype.toString方法。object.prototype.toString()输出的格式就是[object 对象数据类型]。

示例如下:

console.log(Object.prototype.toString.call("jerry"));//[object String]
console.log(Object.prototype.toString.call(12));//[object Number]
console.log(Object.prototype.toString.call(true));//[object Boolean]
console.log(Object.prototype.toString.call(undefined));//[object Undefined]
console.log(Object.prototype.toString.call(null));//[object Null]
console.log(Object.prototype.toString.call({name: "jerry"}));//[object Object]
console.log(Object.prototype.toString.call(function(){}));//[object Function]
console.log(Object.prototype.toString.call([]));//[object Array]
console.log(Object.prototype.toString.call(new Date));//[object Date]
console.log(Object.prototype.toString.call(/\d/));//[object RegExp]
function Person(){};
console.log(Object.prototype.toString.call(new Person));//[object Object]
责任编辑:华轩 来源: 前端Q
相关推荐

2020-06-12 08:28:29

JavaScript开发技术

2023-05-22 08:03:28

JavaScrip枚举定义

2021-07-14 10:31:15

JavaScript开发 技巧

2013-06-14 15:24:57

Android开发移动开发数据存储方式

2021-10-24 08:37:18

网络监控网络架构网络

2021-12-01 23:05:27

物联网计算数据

2013-10-17 09:25:52

2017-04-17 19:31:03

Android多线程

2010-07-28 13:54:42

Flex数据绑定

2020-05-19 20:13:04

物联网计算类型IOT

2021-06-25 08:00:00

物联网医疗技术

2011-05-20 09:55:26

Oracle连接

2015-09-06 09:23:23

Android异步更新

2024-03-20 15:33:12

2022-10-27 14:18:13

Flowable流程变量

2021-12-22 09:34:01

Golagn配置方式

2014-12-25 09:41:15

Android加载方式

2009-07-08 18:20:21

JDBC驱动

2010-08-05 09:33:08

Flex页面跳转

2009-08-20 09:52:31

C#参数类型
点赞
收藏

51CTO技术栈公众号