当前位置: 首页 > news >正文

JavaScript typeof与instanceof的区别

typeofinstanceof 都是 JavaScript 中的运算符,用于检查数据类型或对象的类型。它们有不同的用途和适用场景:

1. typeof

  • 作用:返回变量的数据类型,适用于原始数据类型(如 numberstringboolean 等)。
  • 使用场景:判断一个变量是否为基本类型,如 undefinednumberstringbooleanobject(包括 null)、function 等。
  • 例子
    console.log(typeof 42); // "number"
    console.log(typeof "Hello"); // "string"
    console.log(typeof undefined); // "undefined"
    console.log(typeof {}); // "object"
    console.log(typeof null); // "object"
    

注意:对于数组和 nulltypeof 会返回 "object",因此不适合用于区分复杂对象。

2. instanceof

  • 作用:用于检测一个对象是否是某个构造函数的实例,适用于引用数据类型(如 ArrayFunction、自定义对象等)。
  • 使用场景:判断某个对象是否继承自某个构造函数的原型链,用于复杂对象类型的判断。
  • 例子
    console.log([] instanceof Array); // true
    console.log({} instanceof Object); // true
    console.log(function(){} instanceof Function); // true
    

注意instanceof 适用于对象和类的关系检测,无法用于基本类型的判断。

区别:

  • typeof 更适合基本类型的检测,而 instanceof 适合检测对象的原型链。
  • typeof 是单一操作符,不需要参数,instanceof 是用于检测对象的构造函数匹配。

使用建议:

  • 如果需要判断一个变量的 基本类型,用 typeof
  • 如果判断变量是某个 类的实例,用 instanceof
http://www.lryc.cn/news/443971.html

相关文章:

  • C++11 可变的模板参数
  • 手机在网状态查询接口如何用PHP进行调用?
  • MATLAB中多张fig图合并为一个图
  • Java启动Tomcat: Can‘t load IA 32-bit .dll on a AMD 64-bit platform报错问题解决
  • 基于微信小程序的家教信息管理系统的设计与实现(论文+源码)_kaic
  • 【Android】BottomSheet基本用法总结(BottomSheetDialog,BottomSheetDialogFragment)
  • Linux下实现ls命令的功能
  • 【中国留学网-注册_登录安全分析报告】
  • jvm中的程序计数器、虚拟机栈和本地方法栈
  • 安卓数据存储——SharedPreferences
  • 【计算机网络篇】数据链路层 功能|组帧|流量控制与可靠传输机制
  • Apache CVE-2021-41773漏洞复现
  • 带线无人机现身俄罗斯抗干扰技术详解
  • ArcGIS10.2/10.6安装包下载与安装(附详细安装步骤)
  • 生信服务器 | 组蛋白甲基化修饰、DNA亲和纯化测序、优青博导团队指导设计、解读实验结果。
  • 【machine learning-14-特征缩放-归一化】
  • 二叉树堆的建立与排序
  • 【软件测试】Bug 篇
  • oracle 多表查询
  • layui 可以使点击图片放大
  • 制作网上3D展馆需要什么技术并投入多少费用?
  • C++标准库容器类——string类
  • Qt --- 常用控件的介绍 --- 其他控件
  • spark读取数据性能提升
  • 一次使用threading.Thread来实现Pytorch多个模型并发运行的失败案例
  • HashMap源码
  • 探索 Web Speech API:实现浏览器语音识别与合成
  • python基础题练习
  • 工业交换机如何保证数据的访问安全
  • jmeter得到的文档数据处理