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

JavaScript类型判断:解密变量真实身份的神奇技巧

文章目录

    • 1. typeof运算符
    • 2. instanceof运算符
    • 3. Object.prototype.toString
    • 4. Array.isArray
    • 5. 使用constructor属性
    • 6. 使用Symbol.toStringTag
    • 7. 使用is类型判断库
    • 8. 谨慎使用隐式类型转换
    • 结语

在这里插入图片描述

🎉JavaScript类型判断:解密变量真实身份的神奇技巧


  • ☆* o(≧▽≦)o *☆嗨~我是IT·陈寒🍹
  • ✨博客主页:IT·陈寒的博客
  • 🎈该系列文章专栏:Java学习路线
  • 📜其他专栏:Java学习路线 Java面试技巧 Java实战项目 AIGC人工智能 数据结构学习
  • 🍹文章作者技术和水平有限,如果文中出现错误,希望大家能指正🙏
  • 📜 欢迎大家关注! ❤️

JavaScript是一门弱类型语言,变量的类型是在运行时动态确定的。因此,在处理复杂的代码逻辑时,对于变量的类型判断变得尤为重要。本文将介绍一些JavaScript中常用的类型判断技巧,帮助开发者更好地理解和处理不同类型的变量。

在这里插入图片描述

1. typeof运算符

JavaScript中最基本的类型判断工具是typeof运算符,它可以返回一个字符串,表示未经计算的操作数的类型。以下是一些基本类型的typeof运算的结果:

console.log(typeof 42);         // "number"
console.log(typeof "hello");    // "string"
console.log(typeof true);       // "boolean"
console.log(typeof undefined);  // "undefined"
console.log(typeof null);       // "object"
console.log(typeof []);         // "object"
console.log(typeof {});         // "object"
console.log(typeof function(){});// "function"

需要注意的是,typeof null返回的是"object",这是JavaScript的一个历史遗留问题。而对于数组和对象,typeof同样返回"object",无法准确区分它们。

2. instanceof运算符

instanceof运算符用于测试构造函数的prototype属性是否出现在对象的原型链中的任何位置。它可以用来检查一个对象是否是某个类的实例。以下是一个简单的例子:

class Animal {}class Dog extends Animal {}const dog = new Dog();console.log(dog instanceof Dog);    // true
console.log(dog instanceof Animal); // true

instanceof的缺点是无法判断基本数据类型,仅适用于对象类型的判断。

3. Object.prototype.toString

Object.prototype.toString方法返回一个表示对象的字符串,其中包含了对象的类型信息。通过使用该方法,可以实现对基本数据类型和对象的准确判断:

function getType(obj) {return Object.prototype.toString.call(obj).slice(8, -1).toLowerCase();
}console.log(getType(42));         // "number"
console.log(getType("hello"));    // "string"
console.log(getType(true));       // "boolean"
console.log(getType(undefined));  // "undefined"
console.log(getType(null));       // "null"
console.log(getType([]));         // "array"
console.log(getType({}));         // "object"
console.log(getType(function(){}));// "function"

通过Object.prototype.toString方法,我们可以明确判断出数组、对象、函数等类型。

4. Array.isArray

对于数组的判断,ES6提供了Array.isArray方法,更为直观和方便:

console.log(Array.isArray([]));      // true
console.log(Array.isArray({}));      // false
console.log(Array.isArray("hello")); // false

5. 使用constructor属性

每个JavaScript对象都有一个constructor属性,指向创建该对象的构造函数。通过比较对象的constructor属性,我们可以判断其类型:

function getType(obj) {return obj.constructor.name.toLowerCase();
}console.log(getType(42));         // "number"
console.log(getType("hello"));    // "string"
console.log(getType(true));       // "boolean"
console.log(getType(undefined));  // "undefined"
console.log(getType(null));       // "null"
console.log(getType([]));         // "array"
console.log(getType({}));         // "object"
console.log(getType(function(){}));// "function"

需要注意的是,使用constructor属性需要确保对象是通过构造函数创建的,而不是通过字面量或其他方式创建的。

6. 使用Symbol.toStringTag

ES6引入了Symbol.toStringTag符号,它是一个内置的Symbol值,可以用来自定义对象的toString方法返回的字符串标签。通过使用Symbol.toStringTag,我们可以进一步增强类型判断:

const obj = {};
obj[Symbol.toStringTag] = "MyObject";console.log(Object.prototype.toString.call(obj)); // "[object MyObject]"

7. 使用is类型判断库

在实际项目中,为了提高代码的可读性和减少出错的可能性,可以使用一些专门的类型判断库,例如lodash中的isStringisObject等方法:

const _ = require('lodash');console.log(_.isString("hello")); // true
console.log(_.isObject({}));      // true

这些方法对于复杂的类型判断场景提供了更便捷的解决方案。

8. 谨慎使用隐式类型转换

在JavaScript中,由于存在隐式类型转换,有时候可能会导致意外的结果。例如,"5" == 5返回true,但"5" === 5返回false。因此,在进行类型判断时,应该使用严格相等运算符===,避免隐式类型转

换带来的问题。

console.log("5" == 5);   // true
console.log("5" === 5);  // false

结语

通过本文的介绍,我们了解了JavaScript中一些常用的类型判断技巧,包括typeof运算符、instanceof运算符、Object.prototype.toString方法、Array.isArray方法、constructor属性、Symbol.toStringTag符号、使用is类型判断库以及谨慎使用隐式类型转换等。在实际开发中,根据具体情况选择合适的方法进行类型判断,可以提高代码的可读性和健壮性,减少潜在的Bug。

同时,随着JavaScript语言的发展,未来可能会有更多更便捷的类型判断方式出现,开发者们也可以持续关注和学习,保持对新技术的敏感度,不断优化和提升自己的代码水平。


🧸结尾 ❤️ 感谢您的支持和鼓励! 😊🙏
📜您可能感兴趣的内容:

  • 【Java面试技巧】Java面试八股文 - 掌握面试必备知识(目录篇)
  • 【Java学习路线】2023年完整版Java学习路线图
  • 【AIGC人工智能】Chat GPT是什么,初学者怎么使用Chat GPT,需要注意些什么
  • 【Java实战项目】SpringBoot+SSM实战:打造高效便捷的企业级Java外卖订购系统
  • 【数据结构学习】从零起步:学习数据结构的完整路径

在这里插入图片描述

相关文章:

JavaScript类型判断:解密变量真实身份的神奇技巧

文章目录 1. typeof运算符2. instanceof运算符3. Object.prototype.toString4. Array.isArray5. 使用constructor属性6. 使用Symbol.toStringTag7. 使用is类型判断库8. 谨慎使用隐式类型转换结语 🎉JavaScript类型判断:解密变量真实身份的神奇技巧 ☆* o…...

MT6893_天玑 1200芯片规格参数介绍_datasheet规格书

天玑 1200(MT6893)是一款专为旗舰级全新5G芯片,它融合了先进的AI、相机和多媒体技术,为用户带来令人惊叹的体验。采用先进的6纳米制程设计,内置各种先进技术。该芯片采用旗舰级的八核CPU架构设计,支持16GB强大的四通道内存以及双通…...

【Android踩过的坑】13.Android Studio 运行成功,但APP没有安装上的问题

【Android踩过的坑】13.Android Studio 运行成功,但APP没有安装上的问题 解决办法: 在app的build.gradle文件下添加以下代码 android {...//android.useNewApkCreatorfalse 在高版本gradle下无效,添加以下代码解决冲突即可packagingOptions…...

redis安装配置

Windows 下 Redis 安装与配置 教程_redis windows-CSDN博客 启动Redis服务 打开cmd窗口,切换到Redis安装路径,输入 redis-server 启动 redis 服务...

企业数字化转型应对传统网络挑战的关键策略

数字化变革正在以前所未有的速度和规模改变着我们的生活和工作方式,使得传统网络架构面临着巨大的挑战。其中包括带宽需求增加、多云应用增加、安全威胁增加以及传统网络设备无法满足需求等问题。 数字化时代需要更高速、更可靠、更安全的网络支持,传统网…...

Java 多线程基础 线程4种创建方式

目录 什么是进程什么是多线程使用多线程的好处使用多线程的应用场景单线程与多线程之间的区别如何理解线程上下文切换使用多线程真的开启越多越好吗线程4种创建的方式1.继承Thread类2.使用Runnable3.使用Callable4.线程池的方式 多线程五种的状态如何优雅的停止一个线程 什么是…...

C++概念相关练习题

目录 一、内存管理 二、运算符重载 三、this指针 四、构造&析构函数 一、内存管理 下面有关c内存分配堆栈说法错误的是( ) A.对于栈来讲,是由编译器自动管理,无需我们手工控制;对于堆来说,释放工作由程序员控制 B. 对…...

区间合并笔记

文章目录 什么是区间合并怎么做区间合并AcWing 803. 区间合并思路解析my - CODEdalao の CODE 什么是区间合并 区间合并是指给定多个区间,让你将重合的区间合并为一个区间 怎么做区间合并 区间合并类问题大多三个办法: 按左端点排序按右端点排序按左右…...

青少年CTF之PHP特性练习(1-5)

青少年CTF-PHP特性练习 文章目录 青少年CTF-PHP特性练习PHP特性01PHP特性02PHP特性03PHP特性04PHP特性05 PHP特性01 看给出的源码&#xff0c;两个变量的值加密后的MD5相同 <?php$s1 "%af%13%76%70%82%a0%a6%58%cb%3e%23%38%c4%c6%db%8b%60%2c%bb%90%68%a0%2d%e9%47…...

《opencv实用探索·七》一文看懂图像卷积运算

1、图像卷积使用场景 图像卷积是图像处理中的一种常用的算法&#xff0c;它是一种基本的滤波技术&#xff0c;通过卷积核&#xff08;也称为滤波器&#xff09;对图像进行操作&#xff0c;使用场景如下&#xff1a; 模糊&#xff08;Blur&#xff09;&#xff1a; 使用加权平…...

RPA机器人如何确保敏感数据的安全性

数据资源作为数字化时代的关键要素&#xff0c;其重要性一直受到高度重视&#xff0c;由此&#xff0c;数据安全也成为企业和个人必须面对的重要问题。随着RPA技术在各个行业的广泛应用&#xff0c;其系统安全性也成了每个企业关注的重中之重。经验丰富的RPA专家可以有效地采取…...

微信号被封了怎么办

13-7 常在河边走&#xff0c;哪有不湿鞋&#xff0c;做为经常用微信做电商客服的&#xff0c;或者经常在微信上和顾客谈钱的&#xff0c;总是会被微信后台重点关注&#xff0c;一不小心就有可能被封号。 如果遇到太倒霉的时候&#xff0c;永久封号了&#xff0c;这个时候微信…...

关于 ls -s 输出文件大小的单位问题的讨论

自己看书正好看到这里&#xff0c;正纳闷呢&#xff0c;上网查了下&#xff0c;发现不是我自己在为这个问题感到困惑。 有个大哥提出一个问题&#xff1a; 问题标题&#xff1a; ls -s的单位到底是什么&#xff1f; man ls -s, --size print the alloca…...

JSON.stringify方法详解 后端接受JSON数据格式

1、方法定义&#xff1a;JSON.stringify(value, replacer, space) 参数说明&#xff1a; value&#xff1a;js对象 replacer&#xff1a;替换对象&#xff0c;可以是一个方法、对象或数组&#xff0c;将value按照替换规则展示。 space&#xff1a;填充参数&#xff0c;可以是数…...

vue请求如何按顺序执行

我们有时候会碰到这种情况&#xff0c;需要连续发送两个请求&#xff0c;第二个请求需要用第一个请求的某个返回值作为参数来作为第二个请求的请求参数。 但是存在一个问题&#xff1a;两个请求都是异步的&#xff0c;他并不按照我们期望的先后顺序来执行。 这时候就需要控制请…...

【java】编译时bug 项目启动前bug合集

文章目录 1. jdk8中 Optional orElseThrow 编译时报错java: 未报告的异常错误X; 必须对其进行捕获或声明以便抛出2. 启动项目时提示 Error running Application: Command line is too long. Shorten command line for Application or also for Spring Boot default configurati…...

Pytorch——多卡GPU训练与单卡GPU训练相互切换

部分深度学习网络默认是多卡并行训练的&#xff0c;由于某些原因&#xff0c;有时需要指定在某单卡上训练&#xff0c;最近遇到一个&#xff0c;这里总结如下。 目录 一、多卡训练1.1 修改配置文件1.2 修改主训练文件1.3 显卡使用情况 二、单卡训练2.1 修改配置文件2.2 显卡使…...

Github项目-CNNResnet9-残差神经网络水果多分类项目

ResNet-论文全文完整翻译注解 - 知乎 你必须要知道CNN模型&#xff1a;ResNet - 知乎 #!/usr/bin/env python # coding: utf-8 #https://github.com/SehajS/cnn-resnet-fruit-classification # # Classifying Fruits from their Images # # This project aims at creating a…...

学习感悟一己之言

学习感悟一己之言 学习上克服困难实际上是克服心理上或认识上的障碍的过程。所谓的理解&#xff0c;就是化陌生为熟悉。看不懂&#xff0c;一方面是因为接触的材料太陌生&#xff0c;即远离你当前的背景知识&#xff1b;另一方面是材料或讲述者的描述刻画不准确或晦涩不当。有了…...

【设计模式-2.3】创建型——原型模式

说明&#xff1a;本文介绍设计模式中&#xff0c;创建型中的原型模式&#xff1b; 飞机大战 创建型设计模式关注于对象的创建&#xff0c;原型模式也不例外。如简单工厂和工厂模式中提到过的飞机大战这个例子&#xff0c;游戏中飞机、坦克对象会创建许许多多的实例&#xff0…...

STM32 SysTick中断:嵌入式系统时间管理的核心原理与实战应用

1. 项目概述&#xff1a;为什么SysTick中断是STM32开发的基石在STM32的嵌入式开发世界里&#xff0c;无论你是刚入门的新手&#xff0c;还是已经做过几个项目的熟手&#xff0c;有一个功能你几乎无法绕开&#xff0c;那就是SysTick——系统滴答定时器。你可能在HAL库的初始化代…...

别再死记公式了!用Python手把手实现粒子群算法(PSO)优化函数寻优

别再死记公式了&#xff01;用Python手把手实现粒子群算法&#xff08;PSO&#xff09;优化函数寻优 粒子群算法&#xff08;PSO&#xff09;作为经典的群体智能优化方法&#xff0c;常被用于解决复杂的非线性优化问题。但大多数教程都停留在数学公式推导层面&#xff0c;让初学…...

Neuralink脑机接口技术解析:从医疗应用到人机共生

1. 项目概述&#xff1a;从科幻到现实的神经接口革命最近几年&#xff0c;一个名字频繁出现在科技和医疗的交叉领域&#xff0c;引发无数讨论与遐想——Neuralink。这不仅仅是一家公司的名字&#xff0c;它更像是一个时代的符号&#xff0c;代表着人类试图用最前沿的工程技术&a…...

如何快速掌握Prism-Samples-Wpf交互性编程:InvokeCommandAction事件驱动开发终极指南

如何快速掌握Prism-Samples-Wpf交互性编程&#xff1a;InvokeCommandAction事件驱动开发终极指南 【免费下载链接】Prism-Samples-Wpf Samples that demonstrate how to use various Prism features with WPF 项目地址: https://gitcode.com/gh_mirrors/pr/Prism-Samples-Wpf…...

文字修仙项目市场价值与商业化分析

文字修仙 AI Agent&#xff1a;市场价值与个人开发者商业化实战指南 一、文字修仙游戏的市场基本面——小众赛道的大机会 1.1 全球文字/互动叙事游戏市场规模与增长 1.2 中文修仙品类的独特生态&#xff1a;QQ群 → 微信 → 抖音 1.3 用户画像&#xff1a;谁在玩文字修仙&…...

RISC-V架构:gp寄存器与链接器松弛

目录 0 相关内容 1 gp&#xff08;global pointer&#xff09;全局指针寄存器 1. gp 寄存器的核心作用&#xff1a;高效访问全局数据 2. 为什么 Cortex-M 没有 gp&#xff1f; 3. gp 寄存器在 FreeRTOS 中的作用 2 链接器松弛 3 如何将全局小变量连接到 .sdata 段并设置 …...

1987年6月27日下午13-15点出生性格、运势和命运

1987年6月17日&#xff0c;下午15点到17点之间&#xff0c;正值盛夏时节&#xff0c;阳光炽烈而漫长。这一天出生的孩子&#xff0c;是中国改革开放后“黄金十年”中诞生的又一批弄潮儿。他们的成长轨迹&#xff0c;与全球化浪潮的涌入、市场经济的深化以及互联网的萌芽几乎同步…...

雷达信号体制识别

雷达信号体制识别 摘要 本文档基于工程中的信号识别流水线入口脚本及其所依赖的核心模块&#xff0c;系统梳理该工程如何实现雷达脉冲信号的体制分类&#xff08;Signal Type Recognition&#xff09;。该流水线采用“脉冲检测 → 脉冲描述字提取 → 脉内特征分析 → 驻留段分段…...

mob源码深度解析:Go语言实现高效Git协作工具的架构奥秘

mob源码深度解析&#xff1a;Go语言实现高效Git协作工具的架构奥秘 【免费下载链接】mob Tool for smooth git handover. 项目地址: https://gitcode.com/gh_mirrors/mo/mob 在团队协作开发中&#xff0c;Git代码交接常常成为效率瓶颈。mob作为一个用Go语言编写的Git协作…...

基于少样本学习和思维链提示的知识概念抽取方法研究

佘霖琳 熊龙洋 陆雪松&#xff08;华东师范大学数据科学与工程学院&#xff0c;上海 200062&#xff09;摘 要 知识概念抽取在教育、医疗、金融领域均有重要的应用价值。知识概念抽取属于命名实体识别的一个细分任务&#xff0c;但是由于缺乏数据集和知识概念实体类型的特殊性&…...