js篇-判断数据类型的方式有哪些

判断数据类型的方式

在面试过程中,经常会被问到的一个问题:JavaScript判断数据的类型的方式有哪些?

在回答上面的问题之前,我们需要知道JavaScript中有哪些数据类型。

在这篇文章你可以了解到:js中包含哪些数据类型、js中的数据类型可以用哪些方式检测、区分一个数据Object还是Array的方法、判断数组的方法。

1. JavaScript中的数据类型

JavaScript一共有八种数据类型,这些数据类型可以将其分为原始数据类型和引用数据类型,这两种类型存储的位置也不一样。

  1. 栈(先进后出):原始数据类型:Number、String、Boolean、Undefined、Null
  2. 堆:引用数据类型:对象(Object)、数组(Array)、函数(Function)

上面提到的内容在本篇不做过多的详细阐释。

2. 使用typeof进行数据类型的检测

js 复制代码
console.log(typeof 1); //number
console.log(typeof '我是字符串'); //string
console.log(typeof true); // boolean
console.lof(typeof undefined); //undefiend
console.log(typeof []); //object
console.log(typeof {}); //object
console.log(typeof null); //object

注意,其中需要注意的是:[]、{}、null判断出来的结果的是object。

3. 使用instanceof判断对象的类型

js 复制代码
console.log(1 instanceof Number); //false
console.log(true instanceof Boolean); //false
console.log('我是字符串' instanceof String); //false

console.log(null instanceof Object);// false
console.log({} instanceof Object);/ true

// 注意这里可以区分数据是Object还是Array
console.log([] instanceof Array); //true
console.log([] instanceof Object); //true

console.log(function(){} instanceof Object); //true
console.log(function(){} instanceof Function); //true

在上述的例子中,我们发现 instanceog 只能正确地判断引用数据类型,而不能判断基本的数据类型。

4.constructor

在举例之前,先来了解一下constructor的作用:

  1. 判断数据类型
  2. 对象实例通过constructor对象访问它的构造函数
js 复制代码
console.log((2).constructor === Number); //true  
console.log((true).constructor === Boolean); //true  
console.log(('str').constructor === String); //true  

// 注意这里可以区分数据是Object还是Array
console.log(([]).constructor === Array);// true  
console.log(([]).constructor === Object);// false  

console.log((function(){}).constructor === Function); //true
console.log(({}).constructor===Object);//true

注释:如果创建一个对象来改变它的原型时,constructor就不能用来判断数据类型,例如:

js 复制代码
function Fn(){};
Fn.prototype = new Array();
let f = new Fn();

console.log(f.constructor === Fn); //false
console.log(f.constructor === Array); //true

5. 使用Object.prototype.toString.call()来判断数据类型

js 复制代码
console.log(Object.prototype.toString.call(2));  //[Object Number]
console.log(Object.prototype.toString.call(true));  //[Object Boolean]
console.log(Object.prototype.toString.call('true'));  //[Object String]
console.log(Object.prototype.toString.call([]));   //[Object Array]
console.log(Object.prototype.toString.call(function(){}));  //[Object Function]
console.log(Object.prototype.toString.call({}));  //[Object Object]
console.log(Object.prototype.toString.call(undefined));  //[Object Undefined]
console.log(Object.prototype.toString.call(null));  //[Object Null]

6. 判断数据的方式

1. instanceOf

js 复制代码
console.log([] instanceof Array); //true

2.Object.prototype.toString.call()

js 复制代码
console.log(Object.prototype.toString.call([]));   //[Object Array]

3.Es6的isArray()

js 复制代码
console.log(Array.isArrray(obj));// true

4. Array.prototype.isPrototypeOf()

js 复制代码
console.log(Array.prototype.isPrototypeOf(obj)) //true

还是那句话~请多多指教。 作者准备跑路中,有没有内推啊

相关推荐
前端小L6 小时前
双指针专题(三):去重的艺术——「三数之和」
javascript·算法·双指针与滑动窗口
web小白成长日记6 小时前
在Vue样式中使用JavaScript 变量(CSS 变量注入)
前端·javascript·css·vue.js
C_心欲无痕6 小时前
react - useImperativeHandle让子组件“暴露方法”给父组件调用
前端·javascript·react.js
霖鸣8 小时前
Minecraft通过kubejs进行简单魔改
javascript
JackieDYH8 小时前
HTML+CSS+JavaScript实现图像对比滑块demo
javascript·css·html
全栈前端老曹9 小时前
【前端路由】Vue Router 嵌套路由 - 配置父子级路由、命名视图、动态路径匹配
前端·javascript·vue.js·node.js·ecmascript·vue-router·前端路由
EndingCoder9 小时前
安装和设置 TypeScript 开发环境
前端·javascript·typescript
张雨zy10 小时前
Vue 项目管理数据时,Cookie、Pinia 和 LocalStorage 三种常见的工具的选择
前端·javascript·vue.js
五月君_10 小时前
Nuxt UI v4.3 发布:原生 AI 富文本编辑器来了,Vue 生态又添一员猛将!
前端·javascript·vue.js·人工智能·ui
一个处女座的程序猿O(∩_∩)O10 小时前
现代前端开发的三大支柱:TypeScript、ESLint、Prettier 深度解析与完美协作
javascript·typescript