首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >JavaScript数据类型检测的四种方式

JavaScript数据类型检测的四种方式

作者头像
henu_Newxc03
发布2022-05-05 18:10:17
发布2022-05-05 18:10:17
3140
举报

🧐 typeof

代码语言:javascript
复制
console.log(typeof 1);// 'number'
console.log(typeof true);// 'boolean'
console.log(typeof 'str');// 'string'
console.log(typeof []);// 'object'
console.log(typeof function(){});// 'function'
console.log(typeof {});// 'object'
console.log(typeof undefined);// 'undefined'
console.log(typeof null);// 'object'

注意: typeof的返回值是字符串 其中数组对象null都会被判断为’object’

😎 instanceof

instanceof可以正确判断对象的类型,其内部运行机制是判断在原型链中能否找到该类型的原型

代码语言:javascript
复制
console.log(1 instanceof Number);// false
console.log(true instanceof Boolean);// false
console.log('str' instanceof String);// false
console.log([] instanceof Array);// true
console.log(function(){} instanceof Function);// true
console.log({} instanceof Object);// true

instanceof只能正确判断引用数据类型,而不能判断基本数据类型。instanceof运算符可以用来测试一个对象在其原型链中是否存在一个构造函数的prototype属性

😜 constructor

代码语言:javascript
复制
console.log((1).constructor===Number);//true
console.log((true).constructor===Boolean);//true
console.log(('str').constructor===String);//true
console.log(([]).constructor===Array);//true
console.log((function(){}).constructor===Function);//true  
console.log(({}).constructor===Object);//true

constructor有两个作用,一个是判断数据类型,二是对象实例通过constructor对象访问它的构造函数。需要注意,如果创建一个对象来改变它的原型,constructor就不能用来判断数据了:

代码语言:javascript
复制
function Fn(){};
Fn.prototype = new Array();
let f = new Fn();
console.log(f.constructor===Fn);    // false
console.log(f.constructor===Array); // true

😋 Object.prototype.toString.call()

Object.prototype.toString.call()使用Object对象的原型方法toString来判断数据类型:

代码语言:javascript
复制
let a = Object.prototype.toString;
console.log(a.call(2));
console.log(a.call(true));
console.log(a.call('str'));
console.log(a.call([]));
console.log(a.call(function(){}));
console.log(a.call({}));
console.log(a.call(undefined));
console.log(a.call(null));

同样是检测对象obj调用toString()方法,obj.toString()的结果和Object.prototype.toString.call(obj)的结果不一样,这是为什么? 这是因为toString是Object的原型方法,而Array,function等类型作为Object的实例,都重写了toString方法。不同的对象类型调用toString()方法时,根据原型链的知识,调用的对应的重写之后的toString方法(function类型返回内容为函数体的字符串,Array类型返回元素组成的字符串…),而不会去调用Object原型上的toString方法(返回对象的具体类型),所以采用obj.toString()不能得到其对象类型,只能将obj转换为字符串类型;因此,在想要得到对象的具体类型时,应该调用Object原型上的toString()方法

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-04-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 🧐 typeof
  • 😎 instanceof
  • 😜 constructor
  • 😋 Object.prototype.toString.call()
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档