聊聊 typeof 和 instanceof 间有什么区别
typeof和instanceof操作符都是用来判断数据类型的,但是它们的使用场景却各不相同,其中一些细节也需要特别注意。接下来让我们一探究竟,彻底掌握该知识点,再也不惧面试官的提问。
typeof
typeof是一个一元运算符,放在一个运算数前面,这个运算数可以是任何类型。它返回一个字符串,说明运算数的类型。请看栗子:
const type = typeof '中国万岁';
// stringtypeof 666;
// numbertypeof true;
// booleantypeof undefined;
// undefinedtypeof Symbol();
// symboltypeof 1n;
// Biginttypeof () =>
{
}
;
// functiontypeof [];
// objecttypeof {
}
;
// objecttypeof new String('xxx');
// objecttypeof null;
// object通过以上例子可以看出,typeof只能准确判断基本数据类型和函数(函数其实是对象,并不属于另一种数据类型,但也能够使用 typeof 进行区分),无法精确判断出引用数据类型(统统返回 object)。
有一点需要注意,调用typeof null返回的是object,这是因为特殊值null被认为是一个对空对象的引用(也叫空对象指针)。
如果想准确判断引用数据类型,可以用instanceof运算符。
instanceof
instanceof运算符放在一个运算数的后面,给定对象的前面。它返回一个布尔值,说明运算数是否是给定对象的实例:
const result = [] instanceof Array;
// trueconst Person = function() {
}
;
const p = new Person();
p instanceof Person;
// trueconst message = new String('xxx');
message instanceof String;
// true区别
typeof 会返回一个运算数的基本类型,instanceof 返回的是布尔值
instanceof 可以准确判断引用数据类型,但是不能正确判断基本数据类型
typeof 虽然可以判断基本数据类型(null 除外),但是无法判断引用数据类型(function 除外)
扩展
Object.PRototype.toString.call()
typeof和instanceof都有一定的弊端,并不能满足所有场景的需求。如果需要通用检测数据类型,可以使用Object.prototype.toString.call()方法:
Object.prototype.toString.call({
}
);
// "[object Object]"Object.prototype.toString.call([]);
// "[object Array]"Object.prototype.toString.call(666);
// "[object Number]"Object.prototype.toString.call('xxx');
// "[object String]"注意,该方法返回的是一个格式为"[object Object]"的字符串。
封装函数
为了更方便的使用,我们可以将这个方法进行封装:
function getType(value) {
let type = typeof value;
if (type !== 'object') {
// 如果是基本数据类型,直接返回 return type;
}
// 如果是引用数据类型,再进一步判断,正则返回结果 return Object.prototype.toString.call(value).replace(/^\[object (\S+)\]$/, '$1');
}
getType(123);
// numbergetType('xxx');
// stringgetType(() =>
{
}
);
// functiongetType([]);
// ArraygetType({
}
);
// ObjectgetType(null);
// Null【相关推荐:javascript视频教程、web前端】
以上就是聊聊 typeof 和 instanceof 间有什么区别的详细内容,更多请关注其它相关文章!
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: 聊聊 typeof 和 instanceof 间有什么区别
本文地址: https://pptw.com/jishu/593611.html
