JS中必须知道的四种数据类型判断方法

开发 前端
js有多种数据类型(Number(数值)、String(字符串)、Boolean(布尔值)、Null、Undefined、Symbol、Object、函数等),在开发过程中难免需要判断数据类型,本文总结了四种判断方法.

[[433821]]

js有多种数据类型(Number(数值)、String(字符串)、Boolean(布尔值)、Null、Undefined、Symbol、Object、函数等),在开发过程中难免需要判断数据类型,本文总结了四种判断方法:

 typeof

typeof是一个运算符,其有两种使用方式:(1)typeof(表达式);(2)typeof 变量名;返回值是一个字符串,用来说明变量的数据类型;所以可以用此来判断number, string, object, boolean, function, undefined, symbol 这七种类型,每种情况返回的内容如下表所示:(具体进阶可看前端百题斩【001】) 

 

小试牛刀 

  1. // 字符串 
  2. console.log(typeof('lili')); // string 
  3. // 数字 
  4. console.log(typeof(1)); // number 
  5. // 布尔值 
  6. console.log(typeof(true)); // boolean 
  7. // undefined 
  8. console.log(typeof(undefined)); // undefined 
  9. // 对象 
  10. console.log(typeof({})); // object 
  11. // 数组 
  12. console.log(typeof([])); // object 
  13. // null 
  14. console.log(typeof(null)); // object 
  15. // 函数 
  16. console.log(typeof(() => {})); // function 
  17. // Symbol值 
  18. console.log(typeof(Symbol())); // symbol 

instanceof

instanceof运算符用于检测构造函数的 prototype属性是否出现在某个实例对象的原型链上,返回值为布尔值,用于指示一个变量是否属于某个对象的实例。其语法如下所示:(具体进阶可看前端百题斩【001】) 

  1. object instanceof constructor 

小试牛刀 

  1. const arr = [1, 2]; 
  2. // 判断Object的prototype有没有在数组的原型链上 
  3. console.log(arr instanceof Object); // true 
  4. // 数组arr的原型 
  5. const proto1 = Object.getPrototypeOf(arr); 
  6. console.log(proto1); // [] 
  7. // 数组arr的原型的原型 
  8. const proto2 = Object.getPrototypeOf(proto1); 
  9. console.log(proto2); // [] 
  10. // Object的prototype 
  11. console.log(Object.prototype); 
  12. // 判断arr的原型是否与Object的prototype相等 
  13. console.log(proto1 === Object.prototype); // false 
  14. // 判断arr的原型的原型是否与Object的prototype相等 
  15. console.log(proto2 === Object.prototype); // true 

 constructor

该种判断方式其实涉及到原型、构造函数和实例之间的关系,更深层次的讲解将放到后面的内容,下面只需要简单了解一下这三者关系即可。 

 

在定义一个函数(构造函数)的时候,JS引擎会为其添加prototype原型,原型上有其对应的constructor属性指向该构造函数,从而原型和构造函数之间互相知道对方。当构造函数实例化的时候,会产生对应的实例,其实例可以访问对应原型上的constructor属性,这样该实例就可以了解到通过谁产生了自己,这样就可以在新对象产生之后了解其数据类型。

小试牛刀 

  1. const val1 = 1; 
  2. console.log(val1.constructor); // [Function: Number] 
  3. const val2 = 'abc'
  4. console.log(val2.constructor); // [Function: String] 
  5. const val3 = true
  6. console.log(val3.constructor); // [Function: Boolean] 

虽然该方法可以判断其数据类型,但存在两个缺点:

  1. null 和 undefined 是无效的对象,因此是不会有 constructor 存在的,这两种类型的数据需要通过其他方式来判断。
  2. 函数的 constructor 是不稳定的,这个主要体现在自定义对象上,当开发者重写 prototype 后,原有的 constructor 引用会丢失,constructor 会默认为 Object

 toString()

toString() 是 Object 的原型方法,调用该方法,默认返回当前对象的 [[Class]] 。这是一个内部属性,其格式为[object Xxx] ,其中 Xxx 就是对象的类型。所以利用Object.prototype.toString()方法可以对变量的类型进行比较准确的判断。该类型针对不同不同变量的类型返回的结果如下所示: 

 

利用该方法很容易构建一个鉴型函数,代码如下所示: 

  1. function type(target) { 
  2.     const ret = typeof(target); 
  3.     const template = { 
  4.         "[object Array]""array",  
  5.         "[object Object]":"object"
  6.         "[object Number]":"number - object"
  7.         "[object Boolean]":"boolean - object"
  8.         "[object String]":'string-object' 
  9.     } 
  10.     if(target === null) { 
  11.         return 'null'
  12.     } 
  13.     else if(ret == "object"){ 
  14.         const str = Object.prototype.toString.call(target); 
  15.         return template[str]; 
  16.     } 
  17.     else
  18.         return ret; 
  19.     } 

小试牛刀 

  1. console.log(type({})); // object 
  2. console.log(type(123)); // number 
  3. console.log(type('123')); // string 

 

责任编辑:姜华 来源: 前端点线面
相关推荐

2016-11-10 13:00:32

网络传输协议pythonhttp

2015-07-23 14:50:28

大数据

2020-04-02 15:37:58

数据结构存储

2023-01-10 08:12:52

Java程序员负载均衡

2022-10-27 09:50:41

数据仓开发

2021-03-12 08:02:34

Redis数据类型.

2016-08-01 10:42:58

数据类型WebWordPress

2010-05-26 17:05:48

MySQL数据类型

2014-04-25 09:38:08

大数据

2009-02-25 09:52:14

类型转换.NET 强制转型

2009-06-09 10:05:41

jQuery

2020-07-24 09:56:12

React开发数据

2020-12-29 09:50:23

大数据大数据技术

2021-10-24 08:37:18

网络监控网络架构网络

2017-08-01 23:44:25

数据分析数据科学数据

2023-11-01 08:01:48

数据结构软件工程

2022-12-15 08:00:00

2024-10-16 18:09:54

2020-03-19 15:30:08

JavaScript数组字符串

2018-09-13 14:51:43

NoSQL数据库大数据
点赞
收藏

51CTO技术栈公众号