typeof的取值类型范围 ,以及typeof和instanceof 的区别

本文深入探讨JavaScript中的类型检测方法,包括typeof、instanceof和constructor的使用及局限性,特别介绍了跨框架数组检测的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

typeof的取值类型范围 :
typeof 是一个一元运算,放在一个运算数之前,运算数可以是任意类型。
它返回值是五种数据类型 number string boolean undefined object和函数类型 function

在这里插入图片描述

instanceof:
instanceof操作符是确定一个对象是什么类型的对象的工具。
alert(person instanceof Object);//变量person是Object 对象吗?
alert(colors instanceof Array);//变量colors是Array 对象吗?
alert(pattern instanceof RegExp);//变量pattern是RegExp 对象吗?
所有引用类型的值都是Object的实例。

区别:typeof是判断变量是什么基本类型的;
instanceof是判断对象到底是什么类型的;
constructor:
function isArray(arr){
return typeof arr == “object” && arr.constructor == Array;
}
很多情况下,我们可以使用instanceof运算符或对象的constructor属性来检测对象是否为数组。例如很多JavaScript框架就是使用这两种方法来判断对象是否为数组类型。 但是检测在跨框架(cross-frame)页面中的数组时,会失败。原因就是在不同框架(iframe)中创建的数组不会相互共享其prototype属性

跨原型链调用toString()方法:Object.prototype.toString()。可以解决上面的跨框架问题。 当Object.prototype.toString(o)执行后,会执行以下步骤: 1)获取对象o的class属性。 2)连接字符串:"[object “+结果(1)+”]" 3)返回 结果
Object.prototype.toString.call([]); // 返回 “[object Array]”
Object.prototype.toString.call(/reg/ig); // 返回 “[object RegExp]”

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值