首页 > 编程语言 >JavaScript判断数据为对象(转载)

JavaScript判断数据为对象(转载)

时间:2024-06-12 09:32:24浏览次数:15  
标签:JavaScript console log 对象 Object object toString typeof 转载

  • 1. javaScript判断数据为对象

    • 1.1. Object.prototype.toString.call()

  • 2. JavaScript如何判断数据类型

    • 2.1. typeof

    • 2.2. Array.isArray()

    • 2.3. instanceof

    • 2.4. Object.prototype.toString.call()

    • 2.5. constructor

    • 2.6. 使用ES6的Symbol.toStringTag属性

 

1. javaScript判断数据为对象

在JavaScript中,要判断一个数据是否为对象,可以使用typeof操作符结合对象的具体特性来实现。

最常用的方法是利用typeof检查变量是否为"object",但需要注意的是,数组和其他特殊类型如null也会返回"object",因此需要额外的检查来排除这些情况。

下面是一个常用的方法来准确判断一个数据是否为普通对象(不包括数组、null等):

function isPlainObject(value) {
return typeof value === 'object' && value !== null && !Array.isArray(value) && value.constructor === Object;
}

// 使用示例
console.log(isPlainObject({})); // true
console.log(isPlainObject([])); // false
console.log(isPlainObject(null)); // false
console.log(isPlainObject(new Date())); // false

这段代码首先检查value的类型是否为"object"且不为null,然后使用Array.isArray()确保它不是数组,最后通过检查value.constructor是否为Object来确定它是一个普通的对象。

这种方法适用于大多数情况,但请注意,如果对象是通过其他构造函数创建的(例如,自定义类的实例),则可能需要更复杂的逻辑来准确判断。

1.1. Object.prototype.toString.call()

在ES6及以后的版本中,除了上述方法外,还可以利用Object.prototype.toString.call()方法来更精确地判断一个值是否为普通对象。

这个方法会返回一个表示该值的字符串,对于普通对象,它会返回"[object Object]"。这种方法能更准确地处理像null、数组或函数等边缘情况。

下面是使用这种方法判断是否为普通对象的例子:

function isPlainObject(value) {
return Object.prototype.toString.call(value) === '[object Object]';
}

// 使用示例
console.log(isPlainObject({})); // true
console.log(isPlainObject([])); // false
console.log(isPlainObject(null)); // false
console.log(isPlainObject(function() {})); // false

这种方法相比之前的示例,能够避免因构造函数被修改而导致的误判,并且不需要特别排除数组和null的情况,因为它直接比较了对象的类型字符串,这对于判断是否为普通对象来说是一种更为直接且准确的方式。

2. JavaScript如何判断数据类型

在JavaScript中,判断数据类型有多种方法,以下是几种常见和实用的方法:

2.1. typeof

  • 适用于基本数据类型(number, string, boolean, undefined, symbol, bigint)和函数(返回"function"),但对于数组和null,它会分别返回"object"。

console.log(typeof 42); // "number"
console.log(typeof "hello"); // "string"
console.log(typeof true); // "boolean"
console.log(typeof undefined); // "undefined"
console.log(typeof Symbol()); // "symbol"
console.log(typeof BigInt(42)); // "bigint"
console.log(typeof function(){}); // "function"
console.log(typeof []); // "object" (注意)
console.log(typeof null); // "object" (注意)

2.2. Array.isArray()

特别用于判断是否为数组。

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

2.3. instanceof

用于判断一个对象是否是某个构造函数的实例,适用于复杂数据类型。

console.log(new Date() instanceof Date); // true

2.4. Object.prototype.toString.call()

这是最准确的判断方式,可以区分所有类型的对象,包括数组、正则表达式等。

console.log(Object.prototype.toString.call([])); // "[object Array]"
console.log(Object.prototype.toString.call(/regex/)); // "[object RegExp]"

2.5. constructor

虽然可以用来判断对象的构造函数,但由于构造函数可以被修改,所以不是非常可靠。

console.log(({}).constructor === Object); // true

2.6. 使用ES6的Symbol.toStringTag属性

通过定义或检查对象的Symbol.toStringTag属性,可以在Object.prototype.toString.call()的结果中定制部分输出。

let myObj = {};
Object.defineProperty(myObj, Symbol.toStringTag, { value: 'MyObject' });
console.log(Object.prototype.toString.call(myObj)); // "[object MyObject]"

选择合适的方法取决于具体需求,但通常Object.prototype.toString.call()提供最全面和准确的数据类型判断。

标签:JavaScript,console,log,对象,Object,object,toString,typeof,转载
From: https://www.cnblogs.com/pacific2020/p/18243312

相关文章

  • 面向对象设计原则概述
    面向对象设计原则概述面向对象设计原则概述面向对象设计原则概述单一职责原则开闭原则里氏代换原则依赖倒转原则接口隔离原则合成复用原则迪米特法则内容来自《设计模式与艺术》一文。后续会陆续分享书中值得深思观点。面向对象设计的目标之一在于支持可维护性复......
  • 基本数据类型 String,null 和 undefined,运算符,流程控制,JavaScript之数组,数组常用
    Ⅰ基本数据类型String【一】String类型String类型就是字符串类型【二】定义变量【1】常规变量var变量名="变量值";//一般用这种var变量名='变量值';不支持三引号【2】可以先声明不赋值先用varb;再对变量b赋值varb='6';【三】字符串的格式化输出语法......
  • 神奇的JavaScript弱等价类型转换
    JavaScript语言特性-类型转换JavaScript这门语言的类型系统从来没有它表面看起来的那样和善,虽然比起Java、C#等一众强类型语言,它的弱类型使用起来似乎是如此便利,但正因为它极高的自由度,所以才会衍生出令人摸不着头脑的荒诞行为。举个例子,虽然我们都知道一个包含内容的字符串会......
  • 大学生HTML期末大作业——HTML+CSS+JavaScript美食网站(零食)
    HTML+CSS+JS【美食网站】网页设计期末课程大作业web前端开发技术web课程设计网页规划与设计......
  • 大学生HTML期末大作业——HTML+CSS+JavaScript购物商城(华为手机)
    HTML+CSS+JS【购物商城】网页设计期末课程大作业web前端开发技术web课程设计网页规划与设计......
  • C# JavaScriptSerializer序列化时的时间处理详解
    原文链接:https://www.jb51.net/article/122143.htm输出如下图所示: 猜测这里是由于js初始化时间的时候往往是向1970/01/01添加毫秒数,JavaScriptSerializer进行序列化的时候也会格式化为距离1970/01/01到当该时间点GMT+0时间的毫秒数,如果直接反序列化可以看到少了8小时,且......
  • C++面向对象语言自制多级菜单
    因为要做一个小应用,需要一个菜单类,在网上找了许久,也没有找到一款心仪的菜单类,索性用C++语言,自制一个命令行级别的菜单类,并制作成库,现记录下来,供以后借鉴。一、特性无限制条目无限制层级用户自定义条目和动作脚本式生成菜单类二、代码实现(一)菜单类菜单类主要负责菜单的......
  • JavaScript中什么是类,如何使用?
    在JavaScript中,类是一种用于创建对象的模板。它定义了对象的属性和方法,并可以通过实例化来创建具体的对象。类提供了一种结构化的方式来组织和管理代码,使得代码更易于理解和维护。下面我将通过三个例子来详细说明JavaScript中类的概念和使用方法。例子1:创建一个表示人的类cl......
  • 【Go语言】面向对象编程(二):通过组合实现类的继承和方法重写
    通过组合实现类的继承和方法重写要实现面向对象的编程,就必须实现面向对象编程的三大特性:封装、继承和多态。1封装类的定义及其内部数据的定义可以看作是类的属性,基于类定义的函数方法则是类的成员方法。2继承Go语言中,没有直接提供继承相关的语法实现,可以通过组合......
  • JavaScript基础语法
    原文链接:https://blog.csdn.net/m0_67683346/article/details/1275910796.2、console.log在控制台打印一个日志(一般是给程序员看的):console.log("helloJavaScript");需要在开发者工具中的控制台查看打印结果:  ★console是JS中的一个“对象”,.表示取对象中的某个属性或......