JavaScript中检测数据类型的四种方法

yizhihongxing

当我们在进行 JavaScript 的开发时,必须经常检测数据类型以确保代码的正确性。本文将介绍 JavaScript 中检测数据类型的四种方法。

方法一:typeof 操作符

typeof 操作符用于检测变量的数据类型,返回一个字符串,表明该变量的数据类型。

console.log(typeof 'Hello World'); // string
console.log(typeof 123); // number
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 Bug, 因为在 JavaScript 的实现中,null 是对 Null 指针的引用。

方法二:instanceof 操作符

instanceof 操作符用于检测对象的类型,返回一个布尔值,表明该对象是否属于指定类型的实例。

console.log('Hello World' instanceof String); // false
console.log(new String('Hello World') instanceof String); // true
console.log(123 instanceof Number); // false
console.log(new Number(123) instanceof Number); // true
console.log(true instanceof Boolean); // false
console.log(new Boolean(true) instanceof Boolean); // true
console.log([] instanceof Array); // true
console.log({} instanceof Object); // true

需要注意的是,如果检测变量是基本数据类型的值,该方法会返回 false。

方法三:Object.prototype.toString.call() 方法

Object.prototype.toString.call() 方法用于检测对象的类型,返回一个字符串,表明该对象的数据类型。

console.log(Object.prototype.toString.call('Hello World')); // [object String]
console.log(Object.prototype.toString.call(123)); // [object Number]
console.log(Object.prototype.toString.call(true)); // [object Boolean]
console.log(Object.prototype.toString.call(undefined)); // [object Undefined]
console.log(Object.prototype.toString.call(null)); // [object Null]
console.log(Object.prototype.toString.call([])); // [object Array]
console.log(Object.prototype.toString.call({})); // [object Object]
console.log(Object.prototype.toString.call(function(){})); // [object Function]

需要注意的是,该方法对于 null 和 undefined,会返回 [object Null] 和 [object Undefined]。

方法四:Array.isArray() 方法

Array.isArray() 方法用于检测对象是否为数组,返回一个布尔值。

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

需要注意的是,该方法对于类数组对象(如 DOM NodeList)并不适用。

综上所述,这四种方法都可以被用来检测 JavaScript 中的数据类型,各有各的优缺点,请根据实际需要选择合适的方法。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:JavaScript中检测数据类型的四种方法 - Python技术站

(0)
上一篇 2023年6月10日
下一篇 2023年6月10日

相关文章

  • js中动态创建json,动态为json添加属性、属性值的实例

    让我们来详细讲解一下JS中动态创建JSON、动态为JSON添加属性、属性值的实例。 一、什么是JSON JSON,全称为JavaScript Object Notation,是一种结构化的数据格式。它以文本的形式表示数据,比XML更加轻量级,也更容易解析。JSON由键值对构成,键值对之间用逗号分隔,最外层使用花括号{}。 JSON的键必须是字符串类型,值可以…

    JavaScript 2023年5月27日
    00
  • 求js数组的最大值和最小值的四种方法

    针对“求js数组的最大值和最小值的四种方法”,我为您提供以下攻略: 方法一:使用Math.max()和Math.min() 我们可以使用Math.max()和Math.min()方法来获取一个数组中的最大值和最小值。 代码示例 const numbers = [3, 6, 2, 8, 1]; const max = Math.max(…numbers);…

    JavaScript 2023年5月27日
    00
  • JavaScript使用cookie实现记住账号密码功能

    一、什么是cookie? 在介绍如何使用cookie实现记住账号密码功能前,我们先来了解一下什么是cookie。 Cookie是一种存储在用户计算机上的小文件。当用户访问网站时,网站会在用户计算机上存储一些数据,并在以后访问该网站时使用这些数据。Cookie主要用于跟踪用户,在用户浏览网站时保持用户状态以及在一段时间内记录用户在网站上的活动。 二、使用coo…

    JavaScript 2023年6月11日
    00
  • javascript ajax类AJAXRequest2007-12-31 更新

    JavaScript AJAX类AJAXRequest2007-12-31是一种用于发送AJAX请求的JavaScript类。使用AJAXRequest类可以实现在不刷新页面的情况下,通过后台服务器获取数据并动态更新网页的应用。 下面是使用该类的详细攻略: 1. 引入AJAXRequest类 在使用AJAXRequest类之前,需要将类的代码引入到网页中。可…

    JavaScript 2023年6月10日
    00
  • 深入理解JavaScript系列(22):S.O.L.I.D五大原则之依赖倒置原则DIP详解

    深入理解JavaScript系列(22):S.O.L.I.D五大原则之依赖倒置原则DIP详解 什么是依赖倒置原则DIP? 依赖倒置原则(Dependency Inversion Principle,DIP)是S.O.L.I.D原则中的一个重要原则。该原则的核心思想是:高层模块不应该依赖于低层模块,二者都应该依赖于抽象接口。同时,抽象接口不应该依赖于具体实现,…

    JavaScript 2023年6月11日
    00
  • JS字符串按逗号和回车分隔的方法

    下面是JS字符串按逗号和回车分隔的方法的完整攻略: 方法一:使用 split() 函数分隔字符串 使用 split() 函数可以将一个字符串以某个分隔符分隔开,返回由分隔后的子字符串组成的数组。可以将逗号和回车作为分隔符,然后对返回的数组进行处理。 let str = ‘a,b,c\n1,2,3\nx,y,z’; // 带有逗号和回车的字符串 let row…

    JavaScript 2023年5月28日
    00
  • 详解正则表达式表单验证实例

    下面是“详解正则表达式表单验证实例”的完整攻略。 什么是正则表达式? 正则表达式是一种强大的文本匹配工具,可以用于搜索、过滤和替换字符串。它可以用一些简单的字符和符号表示复杂的字符模式,非常的灵活和高效。 正则表达式在表单验证中的应用 正则表达式最常用的场景之一就是在表单验证中,我们可以通过正则表达式来限定用户输入的格式,确保输入的数据符合规则。下面我们通过…

    JavaScript 2023年6月10日
    00
  • 全面解析JavaScript中的valueOf与toString方法(推荐)

    全面解析JavaScript中的valueOf与toString方法 本文将全面深入地解析JavaScript中的valueOf与toString方法,以及它们的区别和各自的应用场景。 前言 JavaScript是动态的、弱类型的语言,它允许我们对不同类型的值进行各种操作。由于JavaScript的数据类型是动态的,因此只有在执行代码时才能确定变量的数据类型…

    JavaScript 2023年5月28日
    00
合作推广
合作推广
分享本页
返回顶部