Object.prototype.toString()方法判断数据类型的原理

本文详细介绍了JavaScript中toString()方法的工作原理,Object.prototype.toString()用于判断数据类型的方法,以及如何通过call()进行对象类型的检测。此外,还提供了方法封装示例以便更方便地获取对象类型。
摘要由CSDN通过智能技术生成

一、toString()

  • toString() 方法返回一个表示该对象的字符串。
  • Object.prototype.toString()可以看出toString()继承自Object

二、Object.prototype.toString()方法判断数据类型的原理

如果toString() 方法在自定义对象中未被覆盖toString() 返回 [object type],其中 type 是对象的类型。

2.1. toString方法没有被覆盖的情况

例如Object,Math他们直接调用toStirng()方法,可以直接判断出来数据类型

obj.toString(); // "[object Object]"
Math.toString(); // "[object Math]"

2.2. toString方法被覆盖的情况

Number、Boolean、String、Array、Date、RegExp、Function这几种构造函数生成的对象,toString方法都被覆盖了,所以他们无法使用toString()方法判断数据类型

Boolean.prototype.hasOwnProperty("toString"); // true
String.prototype.hasOwnProperty("toString"); // true
Array.prototype.hasOwnProperty("toString"); // true
Date.prototype.hasOwnProperty("toString"); // true
RegExp.prototype.hasOwnProperty("toString"); // true
Function.prototype.hasOwnProperty("toString"); // true
var num = new Number("123sd");
num.toString(); // 'NaN'
var str = new String("12df");
str.toString(); // '12df'
var bool = new Boolean("fd");
bool.toString(); // 'true'
var arr = new Array(1, 2);
arr.toString(); // '1,2'
var d = new Date();
d.toString(); // "Sun Jul 22 2018 12:38:42 GMT+0800 (中国标准时间)"
var func = function () {};
func.toString(); // "function () {}"

三、使用 toString() 检测对象类型

为了每个对象都能通过 Object.prototype.toString() 来检测,需要以 Function.prototype.call() 或者 Function.prototype.apply() 的形式来调用,传递要检查的对象作为第一个参数。

至于call的作用,帮助执行一次Object.prototype.toString方法,并且将函数内部的this替换为call的第一个参数

Object.prototype.toString.call(new Date()); // [object Date]
Object.prototype.toString.call(new String()); // [object String]
Object.prototype.toString.call(Math); // [object Math]

//Since JavaScript 1.8.5
Object.prototype.toString.call(undefined); // [object Undefined]
Object.prototype.toString.call(null); // [object Null]

3.1、方法封装

export const getObjType = (obj) => {
  const toString = Object.prototype.toString;
  const map = {
    "[object Boolean]": "boolean",
    "[object Number]": "number",
    "[object String]": "string",
    "[object Function]": "function",
    "[object Array]": "array",
    "[object Date]": "date",
    "[object RegExp]": "regExp",
    "[object Undefined]": "undefined",
    "[object Null]": "null",
    "[object Object]": "object",
  };
  return map[toString.call(obj)];
};

四、call详解

帮助执行一次函数,并且将函数内部的this替换为call的第一个参数

function.call(thisArg, arg1, arg2, ...)

[thisArg]func 函数运行时使用的 this 值。

let objCall = {
  name: "我是 Call",
};
function fn() {
  console.log("参数 => ", ...arguments);
  console.log("name => ", this.name);
}
fn.call(objCall, 1, 2, 3);
// 参数 =>  1 2 3
// name =>  我是Call
  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值