专栏首页前端重点笔记前端面试题1:Object.prototype.toString.call() 、instanceof 以及 Array.isArray()三种方法判别数组的优劣和区别

前端面试题1:Object.prototype.toString.call() 、instanceof 以及 Array.isArray()三种方法判别数组的优劣和区别

1. Object.prototype.toString.call()

每一个继承 Object 的对象都有 toString 方法,如果 toString 方法没有重写的话,会返回 [Object type],其中 type 为对象的类型。但当除了 Object 类型的对象外,其他类型直接使用 toString 方法时,会直接返回都是内容的字符串,所以我们需要使用call或者apply方法来改变toString方法的执行上下文

const an = ['Hello','An'];
an.toString(); // "Hello,An"
Object.prototype.toString.call(an); // "[object Array]"

优点:这种方法对于所有基本的数据类型都能进行判断,即使是 null和defined,且和下面的Array.isArray方法一样都检测出 iframes

Object.prototype.toString.call('An') // "[object String]"
Object.prototype.toString.call(1) // "[object Number]"
Object.prototype.toString.call(Symbol(1)) // "[object Symbol]"
Object.prototype.toString.call(null) // "[object Null]"
Object.prototype.toString.call(undefined) // "[object Undefined]"
Object.prototype.toString.call(function(){}) // "[object Function]"
Object.prototype.toString.call({name: 'An'}) // "[object Object]"

缺点:不能精准判断自定义对象,对于自定义对象只会返回[object Object]

function f(name) {
    this.name=name;
}
var f1=new f('martin');
console.log(Object.prototype.toString.call(f1));//[object Object]

Object.prototype.toString.call() 常用于判断浏览器内置对象。

2. instanceof

instanceof 的内部机制是通过判断对象的原型链中是不是能找到类型的 prototype

使用 instanceof判断一个对象是否为数组,instanceof 会判断这个对象的原型链上是否会找到对应的 Array 的原型,找到返回 true,否则返回 false

[]  instanceof Array; // true

缺点: instanceof 只能用来判断对象类型,原始类型不可以。并且所有对象类型 instanceof Object 都是 true,且不同于其他两种方法的是它不能检测出iframes

优点:instanceof可以弥补Object.prototype.toString.call()不能判断自定义实例化对象的缺点。

function f(name) {
    this.name=name;
}
var f1=new f('martin');
console.log(f1 instanceof f);//true

3.Array.isArray()

  • 功能:用来判断对象是否为数组
  • instanceof 与 isArray 优点:当检测Array实例时,Array.isArray 优于 instanceof ,因为 Array.isArray 和Object.prototype.toString.call可以检测出 iframes,而instanceof不能
var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
xArray = window.frames[window.frames.length-1].Array;
var arr = new xArray(1,2,3); // [1,2,3]

// Correctly checking for Array
Array.isArray(arr);  // true
Object.prototype.toString.call(arr); // true
// Considered harmful, because doesn't work though iframes
arr instanceof Array; // false

  缺点:只能判别数组

  • Array.isArray()Object.prototype.toString.call()

Array.isArray()是ES5新增的方法,当不存在 Array.isArray() ,可以用 Object.prototype.toString.call() 实现。

if (!Array.isArray) {
  Array.isArray = function(arg) {
    return Object.prototype.toString.call(arg) === '[object Array]';
  };
}

总结:

方法

Array.isArray

instanceof

Object.prototype.toString.call

检测数据类型

数组对象

对象(包括自定义实例化对象)和所有基本类型

对象(不包括自定义实例化对象)和所有基本类型

能否检测iframes

不能

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • JavaScript中数据类型和typeof返回的数据类型

    3.typeof(Object)和typeof(Array)的结果是function,因为Object和Array本身就是内置函数。

    IT人一直在路上
  • Jascript原型链以及Object和Function之间的关系

    从结果可以看到定义一个function,它里边所含有的内容这六个属性是每个function所必有的,直接看第五个prototype(注意prototype是一...

    IT人一直在路上
  • a标签目标链接问题

    2、确定文件寻找路径,因为css.html的父目录是css,而body.html在body目录下,所以需要先退到上一目录head然后再到body目录下寻找bod...

    IT人一直在路上
  • 【Go 语言社区】Go文件操作函数

    文件操作 golang的文件操作时在os包中的。 所以用的时候要import os包 包含以下的这些函数 func Create(n...

    李海彬
  • Linux系列教程(二十三)——Linux的服务管理

      前面我们讲解Linux软件包管理之源码包、脚本安装包时,我们介绍了rpm包和源码包由于安装位置的不同,会对服务的启动造成影响,具体是什么,本篇博客我们来详细...

    IT可乐
  • 关于5G 的十点思考

    本文为邬贺铨院士为《中兴通讯技术》杂志撰写的2020年卷首特稿,边缘计算社区经过授权发布,全文共4556字,内容非常干,预计阅读12分钟。

    边缘计算
  • 马斯克自断右臂!特斯拉工程SVP被曝离职,加盟苹果无人车

    【新智元导读】传奇的车辆工程和硬件大神、前特斯拉高级工程副总裁 Doug Field 在被特斯拉挖走五年之后,现已重返苹果公司,加入苹果秘密造车项目 Proje...

    新智元
  • +从零实现一款12306刷票软件1.4

    这里还有个注意细节,就是通过POST请求发送的数据需要对一些符号做URL Encode,这个我在上一篇文章《从零实现一个http服务器》也详细做了介绍,还不清楚...

    范蠡
  • ajax的再次封装!

    js的动态加载、缓存、更新以及复用 系列有点卡文,放心会继续的。先来点更基础的,为js的加载做点铺垫。   jQuery的ajax本来就很方便了,为啥还要在进一...

    用户1174620
  • 用GenePred注释文件进行数据分析

    编者注:前几天在生信技能树我们发现了一个神奇的帖子(http://www.biotrainee.com/thread-928-1-1.html ), 作者用一种...

    生信技能树

扫码关注云+社区

领取腾讯云代金券