Object.prototype.toString为什么要加.call

问题1:为什么是Object.prototyp不能直接arr.toString

js 复制代码
   console.log("arr.toString()", arr.toString());

    const num = 123;
    console.log("num.toString()", num.toString());

	  const fun = () => {
      console.log("fun");
    };
    console.log("fun.toString()", fun.toString());


    const obj = { name: "slx", age: 3434 };
    console.log("obj.toString", obj.toString());

因为Array和Function等的toString方法都重写了,只有Object的没有被重写,所以只有Object.prototype才可以判断数据类型

问题2:为什么后面要加call()

js 复制代码
 const arr = [1, 2, 3];
    console.log(
      " Object.prototype.toString(arr)",
      Object.prototype.toString(arr)
    );
    console.log(
      " Object.prototype.toString.call(arr)",
      Object.prototype.toString.call(arr)
    );

如果不加.call()的话,this指向为Object,Object的数据类型自然是Object,所以不管判断啥都是Object;

添加call之后,改变this指向arr.才能得到正确的类型结果

理论上使用apply也是可以的

相关推荐
Mike_jia32 分钟前
LiteOps:轻量级CI/CD平台,重塑开发运维新体验
前端
浮游本尊40 分钟前
React 18.x 学习计划 - 第十四天:实战整合与进阶收尾
前端·学习·react.js
_Eleven5 小时前
Tailwind CSS vs UnoCSS 深度对比
前端
NEXT065 小时前
TCP 与 UDP 核心差异及面试高分指南
前端·网络协议·面试
qq_24218863325 小时前
HTML 全屏烟花网页
前端·html
曲幽6 小时前
FastAPI实战:WebSocket长连接保持与心跳机制,从入门到填坑
javascript·python·websocket·keep-alive·fastapi·heartbeat·connection
码云数智-大飞6 小时前
前端性能优化全链路实战:从加载速度到渲染效率的极致提速方案
前端·性能优化
锅包一切6 小时前
【蓝桥杯JavaScript基础入门】一、JavaScript基础
开发语言·前端·javascript·蓝桥杯
NEXT066 小时前
HTTP 协议演进史:从 1.0 到 2.0
前端·网络协议·面试