您好,登录后才能下订单哦!
这期内容当中小编将会给大家带来有关JavaScript中检测数据类型的四种方法分别是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
前言:
在介绍检测数据类型的方法之前,先说说JavaScript中数据类型有哪些吧~
JS数据类型主要分为两大类:基本数据类型和引用数据类型
基本数据类型:number、string、boolean、null、undefined、symbol(es6)
引用数据类型:object(array、function、date...)
数据类型详细介绍请点击这里
检测数据类型四种方法:
typeof
instanceof
constructor
Object.prototype.toString.call()
语法:
typeof(变量) //or typeof 变量
示例:
console.log(typeof ""); //string console.log(typeof 1); //number console.log(typeof true); //boolean console.log(typeof null); //object!!! console.log(typeof undefined); //undefined console.log(typeof []); //object console.log(typeof function(){}); //function console.log(typeof console.log); //function console.log(typeof {}); //object console.log(typeof Symbol()); //symbol(es6) console.log(typeof 23423n); //bigint(谷歌67版本新提出)
总结:
typeof
的返回类型为字符串,值有:number
、boolean
、string
、object
、function
、undefined
、symbol
、bigint
typeof
一般用来判断基本数据类型,除了判断null会输出"object",其它都是正确的
typeof
判断引用数据类型时,除了判断函数会输出"function",其它都是输出"object"
注意:这里涉及两个经常考的面试题!
null
的数据类型是object (null是一个空的引用对象,是一个占位符)
console.log
的数据类型是function
对于引用数据类型的判断,使用typeof并不准确,所以可以使用instanceof来判断引用数据类型
instanceof
可以准确的判断引用数据类型,它的原理是检测构造函数的prototype属性是否在某个实例对象的原型链上
语法:
obj1 instanceof obj2 //obj1 是否是 obj2的实例
示例:
console.log(9 instanceof Number); // false console.log(true instanceof Boolean); // false console.log('libo' instanceof String); // false console.log([] instanceof Array); // true console.log(function(){} instanceof Function); // true console.log({} instanceof Object); // true // 注意以下两组 console.log(typeof null); //object console.log(null instanceof Object); //false !!! console.log(typeof NaN); //number console.log(NaN instanceof Number); //false !!!
总结:
instanceof
用来判断对象,代码形式为 【obj1 instanceof obj2】(obj2 必须为对象,否则会报错!)
instanceof
返回值为布尔值
注意:
instanceof只能用来判断两个对象是否属于实例关系, 而不能判断一个对象实例具体属于哪种类型
当一个函数 F被定义时,JS引擎会为F添加 prototype
原型,然后再在 prototype上添加一个 constructor
属性,并让其指向 F 的引用。
如下所示:
当执行 var f = new F() 时,F 被当成了构造函数,f 是F的实例对象,此时 F 原型上的 constructor 传递到了 f 上,因此f.constructor === F
可以看出,F 利用原型对象上的 constructor
引用了自身,当 F 作为构造函数来创建对象时,原型上的 constructor
就被遗传到了新创建的对象上, 从原型链角度讲,构造函数 F 就是新对象的类型。这样做的意义是,让新对象在诞生以后,就具有可追溯的数据类型。
同样,JavaScript 中的内置对象在内部构建时也是这样做的:
????注意:
null和undefined是无效的对象,所以他们不会有constructor属性!
函数的constructor是不稳定的,主要是因为开发者可以重写prototype,原有的constructor引用会丢失,constructor会默认为Object
为什么变成了 Object?
因为 prototype
被重新赋值的是一个 { }
, { }
是 new Object() 的字面量,因此 new Object() 会将 Object 原型上的 constructor 传递给 { },也就是 Object 本身。
因此,为了规范开发,在重写对象原型时一般都需要重新给 constructor 赋值,以保证对象实例的类型不被篡改。
toString()
是 Object 的原型方法,调用该方法,默认返回当前对象的 [[Class]] 。这是一个内部属性,其格式为 [object Xxx] ,其中 Xxx 就是对象的类型。
对于 Object
对象,直接调用toString()
就能返回 [object Object] 。而对于其他对象,则需要通过 call / apply 来调用才能返回正确的类型信息。
Object.prototype.toString.call('') ; // [object String] Object.prototype.toString.call(1) ; // [object Number] Object.prototype.toString.call(true) ; // [object Boolean] Object.prototype.toString.call(Symbol()); // [object Symbol] Object.prototype.toString.call(undefined) ; // [object Undefined] Object.prototype.toString.call(null) ; // [object Null] Object.prototype.toString.call(new Function()) ; // [object Function] Object.prototype.toString.call(new Date()) ; // [object Date] Object.prototype.toString.call([]) ; // [object Array] Object.prototype.toString.call(new RegExp()) ; // [object RegExp] Object.prototype.toString.call(new Error()) ; // [object Error] Object.prototype.toString.call(document) ; // [object HTMLDocument] Object.prototype.toString.call(window) ; // [object global] window 是全局对象 global 的引用
上述就是小编为大家分享的JavaScript中检测数据类型的四种方法分别是什么了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。