iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >详解在JavaScript中如何判断变量类型
  • 296
分享到

详解在JavaScript中如何判断变量类型

2024-04-02 19:04:59 296人浏览 泡泡鱼
摘要

javascript是一个动态类型语言,在运行时获取变量类型是常用操作,由于JavaScript设计的问题,看似简单的问题,在JavaScript中可能并不简单,比如在社区中流传的下

javascript是一个动态类型语言,在运行时获取变量类型是常用操作,由于JavaScript设计的问题,看似简单的问题,在JavaScript中可能并不简单,比如在社区中流传的下图,仔细看一下这些坑,即便是JavaScript老司机也经常翻车。

上图中typeof NaN会返回number,这可能和你想的不一样,在JavaScript准确的获取变量类型,并不简单,正因为如此,这个问题经常被用来考察面试者,由于程序=数据+算法,而基本数据是数据的基础,所以面试中考察类型也是合理的。

如果面试中你只回答使用typeof获取类型,那大概率是会减分的,那么该如何回答这道题呢?本文将全面系统的介绍如何在JavaScript中判断类型,阅读本文,可以帮你,在工作中,避开类型判断雷区,如果在面试中你回答本文的内容,那么面试官将惊呼,这是高手,比我知道的都多,然后自然是好评喽。

下面先从最简单的例子开始,并一步一步提升难度,扩展思路,先来看第一个例子:

在工作中,对于数据为空的情况,经常要做防御式编程,误区之一是使用非运算符直接判断。但这样做是可能有坑的,比如这会把很多徦值计算在内,常见的徦值有0, '', false, null, undefined等。例如如下的double函数,需要对参数做为空的防御,这里使用非空运算符。

function double(x) {
  // 0会被错误计算
  if (!x) {
    return NaN;
  }
  return x * 2;
}

对于判空,另一种写法是直接和nullundefined作比较,示例如下:

if (x === null || x === undefined) {
  return NaN;
}

虽然逻辑看起来非常正确,但这种写法有一个比较严重的问题,在JavaScript中undefined并不是关键字,而是 window上的一个属性,在 ECMAScript 5 之前这个属性可写的,如果undefined被重新复制,在过时浏览器中会导致判断失效,示例如下:

window.undefined = 1;

// 判断不能生效
if (x === undefined) {
  console.log(111);
}

虽然在现代浏览器中不会有这个 bug,但是如果文法作用域中存在名字为undefined的变量还是会有问题,这被称作undefiined变量覆盖,例如如下代码中,undefined被1覆盖了。

(function () {
  var undefined = 1;
  // 判断不能生效
  if (x === undefined) {
    console.log(111);
  }
})();

关于判空还有比较巧妙的方法,可以只和null判断相等,借助隐式转换达到同样的效果,null是关键字,没有undefined的问题。

// null 和 undefined都会判断
if (x == null) {
}

在全等是最佳实践的背景下,这种做法并不被鼓励,建议使用 typeof 来判断undefined,typeof 通过内部类型判断,不存在undefined变量覆盖的问题。

if (x === null || typeof x === 'undefined') {
}

对于 number 类型,有个需要注意的地方,在 JavaScript 中有个特殊的值叫做 NaN,NaN 的类型也是 number,编码中很少直接使用到 NaN,通常都是在计算失败时会得到这个值。

但将 NaN 作为 number 使用时就会报错,比如调用 NaN 上的toFixed方法,更好的做法是添加 isNaN 的判断,需要注意 number 类型的特殊逻辑。

const x = Math.sqrt(-1); // NaN

// 注意这里的isNaN判断
if (typeof x === 'number' && !isNaN(x)) {
  console.log(x.toFixed(2));
}

也可以使用 ECMAScript 2015 新增的Number.isNaN,和全局函数 isNaN 的区别是,Number.isNaN 不会自行将参数转换成数字,Number.isNaN的逻辑下面的代码类似,Number.isNaN是更好的建议,但是需要注意兼容性的问题

Number.isNaN = function (value) {
  return typeof value === 'number' && isNaN(value);
};

typeof 只能判断基本类型,对于引用类型的到的值都是object

typeof []; // 'object'
typeof {}; // 'object'
typeof c; // 'object'

instanceof 可以用来检测引用类型,其原理是检测 constructor.prototype 是否存在于参数 object 的原型链上

{} instanceof Object // true
[] instanceof Array // true
/reg/ instanceof RegExp // true

instanceof 存在的一个问题是不够准确,原型链上存在的都会返回 true

[] instanceof Array // true
[] instanceof Object // true 注意这里

使用 instanceof 做类型判断时,一定要注意顺序问题,如果顺序错误,可能会得不到正确的结果

function type(x) {
  if (x instanceof Object) {
    return 'object';
  }

  // Array永远得不到正确的类型哦
  if (x instanceof Array) {
    return 'array';
  }
}

instanceof 另一个冷门的问题是存在多个 iframe 时,其判断可能会返回错误的结果,这个问题一般会在多从窗口之间从传递值时发生

[] instanceof window.frames[0].Array // 返回false
[] instanceof window.Array // 返回true

对于数组的判断,更好的办法是使用 ECMAScript 5 带来的新方法Array.isArray,这个在任何情况下都可以得到可靠的结果

Array.isArray([]); // true
Array.isArray(1); // false

另一种常用的判断类型方式是使用,获取内部类型的方法,借助Object.prototype.toString可以获取内部类型的字符串结果

const toString = Object.prototype.toString;

toString.call({}); // [object Object]
toString.call(null); // [object Null]
toString.call(/reg/); // [object RegExp]

需要注意的是,在 ECMAScript 5 之前,undefined 和 null 并不能返回正确的值,如果有兼容性需求,需要注意这个问题

ECMAScript 2015 引入了Symbol.toStringTag可以修改内部类型的值,这会影响toString的返回值,但是需要注意兼容性问题

const toString = Object.prototype.toString;
const obj = {};

toString.call(obj); // '[object Object]'

obj[Symbol.toStringTag] = 'MyObject'; // 修改内部类型

toString.call(obj); // '[object MyObject]'

总结

至此,本文介绍了在JavaScript中判断变量类型的各种方法,可以看到在正确的场景使用正确的方式并不容易,这里推荐大家使用作者维护的type库,type使用的正是本文介绍的知识,其提供了开箱即用的判断函数,经过了很多项目的检验,欢迎大家体验。

到此这篇关于详解在JavaScript中如何判断变量类型的文章就介绍到这了,更多相关JavaScript判断变量类型内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 详解在JavaScript中如何判断变量类型

本文链接: https://www.lsjlt.com/news/153729.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 详解在JavaScript中如何判断变量类型
    JavaScript是一个动态类型语言,在运行时获取变量类型是常用操作,由于JavaScript设计的问题,看似简单的问题,在JavaScript中可能并不简单,比如在社区中流传的下...
    99+
    2024-04-02
  • 如何在 PHP 函数中判断变量类型?
    php 中可以通过 gettype() 函数获取变量类型,该函数返回字符串形式的类型信息,如 string、integer 等。另外,is_* 函数系列可用于判断特定类型,如 is_st...
    99+
    2024-04-17
    php 判断变量类型
  • Python中判断变量类型
    Python中判断变量类型 在Python中,判断变量的类型是一项常见的任务。通过了解变量的类型,我们可以根据需要执行不同的操作,从而实现更灵活的编程。下面我们将介绍几种常用的方法来判断变量的类型,并...
    99+
    2023-10-24
    python 开发语言 Python
  • 如何在JavaScript中判断数据类型
    如何在JavaScript中判断数据类型?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。javascript是一种什么语言javascript是一种动态类型、弱类型的语言,基于对...
    99+
    2023-06-14
  • JavaScript类型如何判断
    这篇“JavaScript类型如何判断”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“JavaScript类型如何判断”文章吧...
    99+
    2023-06-30
  • 如何判断JavaScript类型
    今天小编给大家分享一下如何判断JavaScript类型的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。本文提供四种方法判断js...
    99+
    2023-06-26
  • 如何正确判断变量google.protobuf.Any的类型?
    php小编鱼仔今天要为大家介绍一个关于变量google.protobuf.Any类型的判断方法。在开发过程中,我们经常会遇到需要判断变量类型的情况,而对于google.protobuf...
    99+
    2024-02-09
  • javascript如何判断变量相等
    这篇文章主要介绍javascript如何判断变量相等,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!JavaScript可以做什么1.可以使网页具有交互性,例如响应用户点击,给用户提供更好的体验。2.可以处理表单,检验...
    99+
    2023-06-14
  • JavaScript如何判断数据类型
    这篇文章给大家分享的是有关JavaScript如何判断数据类型的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。判断数据类型使用 Object.prototype.toString 配合闭包,在保证判断数据类型的准确...
    99+
    2023-06-27
  • 怎么在JavaScript中进行类型判断
    这期内容当中小编将会给大家带来有关怎么在JavaScript中进行类型判断,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。JavaScript的作用是什么1、能够嵌入动态文本于HTML页面。2、对浏览器事件...
    99+
    2023-06-14
  • JavaScript 中如何判断变量是否为数字
    这篇文章将为大家详细讲解有关JavaScript 中如何判断变量是否为数字,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。首先创建一些测试变量:let&nbs...
    99+
    2024-04-02
  • Java中如何判断类型
    这篇文章给大家介绍Java中如何判断类型,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 instanceofinstanceof是Java的一个运算符,用来判断一个对象是否为一个类的实例 。用法:boolea...
    99+
    2023-06-16
  • php如何判断变量不存在
    这篇文章主要讲解了“php如何判断变量不存在”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“php如何判断变量不存在”吧!php判断变量不存在的方法:1、通过isset方法检测变量是否设置,并...
    99+
    2023-06-07
  • JavaScript中怎么判断typeof类型
    这篇文章将为大家详细讲解有关JavaScript中怎么判断typeof类型,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1、对于原始类型,除了null,您还可以调用typeof显示正确的类型...
    99+
    2023-06-20
  • 怎么在python中判断变量
    这期内容当中小编将会给大家带来有关怎么在python中判断变量,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Python主要用来做什么Python主要应用于:1、Web开发;2、数据科学研究;3、网络爬虫...
    99+
    2023-06-14
  • php如何判断变量是否存在
    在PHP中,可以使用isset()函数来判断一个变量是否存在。示例如下: $var = 1; if(isset($var)){ ...
    99+
    2024-04-02
  • c语言怎么判断变量数据类型
    在C语言中,可以使用`sizeof`运算符来判断变量的数据类型。`sizeof`运算符返回变量或数据类型的大小(以字节为单位)。 例...
    99+
    2023-10-28
    c语言
  • JavaScript如何判断对象的数据类型
    这篇文章给大家分享的是有关JavaScript如何判断对象的数据类型的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。判断对象的数据类型使用 Object.prototype.toS...
    99+
    2024-04-02
  • Java对象类型的判断详解
    在Java中,可以使用`instanceof`运算符来判断一个对象的类型。`instanceof`运算符用于检查一个对象是否是一个特...
    99+
    2023-08-15
    Java
  • golang如何用type-switch判断interface变量的实际存储类型
    目录用type-switch判断interface的实际存储类型type-switch就刚好帮我解决了这个问题golang任何类型interface{}example1example...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作