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外卖订购系统
  • 【数据结构学习】从零起步:学习数据结构的完整路径

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/207706.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

OpenTSDB(CVE-202035476)漏洞复现及利用

任务一: 复现环境中的命令注入漏洞。 任务二: 利用命令注入执行whoami,使用DNS外带技术获取结果 任务三:使用反弹shell,将漏洞环境中的shell反弹到宿主机或者vps服务器。 任务一: 1.搭建好环境 2.先去了…

Amazon CTO Werner Vogels:2024年及未来四大技术趋势预测

纵观历史,人类已经开发出各种工具和系统来增强自身能力。无论是印刷机还是装配线,这些创新拓宽了我们的能力范围,造就新的工作和职业,我们也不断适应着新生活。这种变化的速度在过去的一年里迅速加快,云技术、机器学习…

整体迁移SVN仓库到新的windows服务器

一、背景 公司原有的SVN服务器年代比较久远经常出现重启情况,需要把SVN仓库重新迁移到新的服务器上,在网上也搜到过拷贝Repositories文件直接在新服务器覆盖的迁移方案,但考虑到原有的操作系统和现有的操作系统版本不一致,SVN版本…

Redis缓存——Spring Cache入门学习

Spring Cache 介绍 Spring Cache 是一个框架,实现了基于注解的缓存功能,只需要简单地加一个注解,就能实现缓存功能。 Spring Cache 提供了一层抽象,底层可以切换不同的缓存实现,例如: EHCacheCaffeineR…

springboot集成邮箱验证功能

准备工作 开启SMTP服务 前往你的邮箱网站,以网易邮箱为例,打开网易邮箱地址,登录你的邮箱,进入邮箱管理后台界面。点击“设置”》》“POP3/SMTP/IMAP”后,点击开启SMTP服务即可。 技术实现 Spring Boot 发送邮件验证…

java审计之java反序列化-CC链

介绍 序列化的本质是内存对象到数据流的一种转换,我们知道内存中的东西不具备持久性,但有些场景却需要将对象持久化保存或传输。 在Java工程中,序列化还广泛应用于JMX,RMI,网络传输(协议包对象&#xff09…

vivado实现分析与收敛技巧4

执行建议 满足以下条件时 , 在建议运行轮次期间执行建议 : • 这些建议处于已启用 (ENABLED) 状态。 • 必须运行 APPLICABLE_FOR 阶段。 • 这些建议必须设置为 AUTO 。 执行建议时 , APPLIED 设置将会更新 , 如下图所示…

vue3动态加载音频文件,用于不同场景加载不同的文件

本文主要介绍如何在vue3中动态加载音频文件。 目录 前言静态加载动态加载import函数watch函数使用watch函数和import函数动态加载音频文件 前言 在vue3中,我们通常使用import xxx from xxxxxx来加载文件,但是如果我们需要加载哪些文件,是需要…

java数据结构(哈希表—HashMap)含LeetCode例题讲解

目录 1、HashMap的基本方法 1.1、基础方法(增删改查) 1.2、其他方法 2、HashMap的相关例题 2.1、题目介绍 2.2、解题 2.2.1、解题思路 2.2.2、解题图解 2.3、解题代码 1、HashMap的基本方法 HashMap 是一个散列表,它存储的内容是键…

Peter算法小课堂—差分与前缀和

差分 Codeforces802 D2C C代码详解 差分_哔哩哔哩_bilibili 一维差分 差分与前缀和可以说成减法和加法的关系、除法和乘法的关系、积分和微分的关系(听不懂吧) 给定数组A,S为A的前缀和数组,则A为S的差分数组 差分数组构造 现…

电子学会C/C++编程等级考试2021年06月(四级)真题解析

C/C++等级考试(1~8级)全部真题・点这里 第1题:数字三角形问题 (图1) 图1给出了一个数字三角形。从三角形的顶部到底部有很多条不同的路径。对于每条路径,把路径上面的数加起来可以得到一个和,你的任务就是找到最大的和。 注意:路径上的每一步只能从一个数走到下一层上和它…

Android Studio新版UI介绍

顶部菜单栏 左侧主要菜单入口项目名称分支名称 展开之后,主要功能与原来菜单栏功能一样,最大的变化就是把setting独立出去了。 而项目名称这里,展开就可以看到打开的历史工程列表,可以直接新建工程,原来需要在项目名称…

vivado实现分析与收敛技巧3-面向非工程用户的智能设计运行建议

要使用智能设计运行功能特性 , 需要 Vivado 工程。这是因为需要进行运行管理。以下指示信息解释了创建综合后工程的最简单方法。这些信息适用于以下流程的用户: • 非工程实现运行 • 使用较低版本的 Vivado 或第三方综合工具进行综合 访问智能设计…

Git——分支应用进阶

主要内容包括以下几个方面: 长期分支和短期分支的类型以及用途。多种分支模型,其中包括基于工作流的主题分支。不同分支模型的发布流程。在多个预览版程序中使用分支修复安全问题。远程跟踪分支和refspecs规范,以及默认远程版本库配置。拉取…

测评补单助力亚马逊,速卖通,国际站卖家抢占市场,提升转化和评分

想要快速提升商品的销量,测评补单这种方法见效是最快的。特别是新品上线,缺少用户评价,转化率不好,很多商家新品上线都会做测评补单,搞些商品好评,不但可以提升转化,同时在平台也可以获得更多展…

Redis:主从复制

目录 概念配置步骤通过命令配置主从复制原理薪火相传反客为主哨兵(Sentinel)模式原理配置SpringBoot整合Sentinel模式 概念 主机更新后根据配置和策略,自动同步到备机的master/slave机制,Master以写为主,Slave以读为主。 作用: …

Python+Requests模块添加cookie

请求中添加cookies 对于某些网站,登录然后从浏览器中获取cookies,以后就可以直接拿着cookie登录了,无需输入用户 名密码。 一、在参数中添加cookie 在发送请求时使用cookies 代码示例: import requests # 1,在参数…

ZFPlayer 在tableView列表中播放视频架构设计

需求背景 需要在如图所示的列表中播放视频,并且播放视频在对应的卡片上,滚动结束的时候, 完整露出封面图的第一个视频自动播放 分析 根据需求,是滚动的时候获取符合条件的cell,并且 在cell的封面图上播放视频&#x…

CSS中的非布局样式+CSS布局 前端开发入门笔记(十一)

CSS中的非布局样式 在CSS中,非布局样式是指那些不会直接影响页面布局的样式。这些样式主要关注的是元素的颜色、字体、背景、边框、阴影等视觉效果。以下是一些常见的非布局CSS样式: 文本样式:包括字体(font-family)…

传统算法:使用 Pygame 实现归并排序

使用 Pygame 模块实现了归并排序的动画演示。首先,它生成一个包含随机整数的数组,并通过 Pygame 在屏幕上绘制这个数组的条形图。接着,通过归并排序算法对数组进行排序,动画效果可视化每一步的排序过程。在排序的过程中,程序将数组递归地分成两半,分别进行排序,然后再将…