详解JS中的instanceof使用及手写instanceof

  1. instanceof 是什么?
    instanceof 是用来判断左侧对象是否是右侧构造函数的实例化对象,或则说左侧对象能否通过其隐式原型 **[[proto]]**在原型链上一层层向上查找到右侧函数的原型对象,即函数原型对象出现在实例对象的原型链上就返回 true
    通俗的理解: 右侧是不是左侧的爸爸、爷爷、祖宗,只要左侧对象继承自右侧函数就为 true
  2. instanceof 使用方式:
    object instanceof 构造函数, 它有两个必传参数,左侧必须为对象类型,右侧必须为函数类型。返回值为 Boolean 类型。
    注:js中万物皆对象,可能会误导大家出现这种写法: 'str' instanceof String,返回值为false,因为 ‘str’ 就是简单的字符串,它和通过String构造函数(new String('str'))创造出来的字符串是有区别的,可自行在控制台打印出来看,其值会封装成String对象类型的字符串,同理 new Number(3) instanceof Number, new Boolean(true) instanceof Boolean ……等等返回值为true。

数组 则可以直接这样写:

[1,2] instanceof Array // true

函数

function test () {} 
test instanceof Function // true

总结如下:

基本数据类型只有通过对应类型构造函数创建出来成对象形式,才会是对应类型构造函数实例(true),直接写基本数据类型值则不是(false),毕竟上面有说到instanceof是用来判断左侧是不是右侧的实例对象,你连对象类型都不是怎么可能为true呢;引用类型可以直接作为左侧实例对象继承自右侧构造函数,返回值为true,如上面数组。

手撕 instanceof

上面有讲到其判断的原理是:通过左侧对象的隐式原型属性 __ proto __ 在原型链上向上一层层查找,找到右侧构造函数的原型对象属性 prototype 就返回 true。明白这一点也就很容易写出自己的 instanceof,注:需要借助循环来实现。

function myInstanceof(obj, func) {
    if(!['function', 'object'].includes(typeof obj) || obj === null) {
    	// 基本数据类型直接返回false,因为不满足instanceof的左侧参数是对象或者说引用类型
        return false
    }
    let proto = obj.__proto__, prototype = func.prototype
    while(proto !== prototype) {
    	// obj.__proto__不等于func.prototype时,继续通过__proto__向上层查找
    	// 当找到原型链尽头Object.prototype.__proto__=null 时还未找到,就返回false
        proto = proto.__proto__
        if(proto === null){
            return false
        }
    }
    // obj.__proto__ 等于 prototype = func.prototype 时,不会进入上面循环,返回true
    // 不等进入上面循环,找到相等时会跳出循环,走到这里返回true
    return true
}
  • 28
    点赞
  • 101
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 JavaScript ,`instanceof` 是一个运算符,用于检查一个对象是否是某个构造函数的实例。它的语法如下: ```javascript object instanceof constructor ``` 其,`object` 是要检查的对象,`constructor` 是要检查的构造函数。 如果 `object` 是 `constructor` 的实例,那么 `instanceof` 运算符返回 `true`;否则返回 `false`。例如: ```javascript const arr = [1, 2, 3]; console.log(arr instanceof Array); // true console.log(arr instanceof Object); // true const str = 'hello'; console.log(str instanceof String); // false(注意:字符串字面量不是 String 类型的实例) console.log(str instanceof Object); // true const num = 123; console.log(num instanceof Number); // false(同样,数值字面量也不是 Number 类型的实例) console.log(num instanceof Object); // true ``` 需要注意的是,`instanceof` 运算符检查的是对象的原型链,而不是对象本身。也就是说,如果 `object` 的原型链出现了 `constructor.prototype`,那么 `object` 就被认为是 `constructor` 的实例。例如: ```javascript function Person(name) { this.name = name; } const p = new Person('Alice'); console.log(p instanceof Person); // true console.log(p instanceof Object); // true Person.prototype = {}; console.log(p instanceof Person); // false(原型链已经改变) console.log(p instanceof Object); // true(仍然是 Object 的实例) ``` ### 回答2: instanceof是Java的一个关键字,用于判断一个对象是否是特定类的实例,或者是其子类的实例。它的使用情况如下: 例如,有一个父类Animal,和它的两个子类Dog和Cat。我们可以使用instanceof关键字来判断一个对象是否是Animal类的实例,或者是Dog或者Cat类的实例。 代码示例: Animal animal = new Animal(); if (animal instanceof Animal) { System.out.println("animal是Animal类的实例"); } if (animal instanceof Dog) { System.out.println("animal是Dog类的实例"); }else { System.out.println("animal不是Dog类的实例"); } 输出结果: animal是Animal类的实例 animal不是Dog类的实例 上面的代码,我们首先将一个父类Animal的实例赋值给animal对象。然后使用instanceof关键字来判断animal对象是否是Animal类的实例。由于animal确实是Animal类的实例,所以第一个if条件成立。而第二个if条件是不成立的,因为animal不是Dog类的实例。 instanceof关键字的使用可以帮助我们在程序对对象的类型进行判断,从而更加灵活地编写代码。当我们不确定一个对象的类型时,可以使用instanceof来判断,避免出现错误。 ### 回答3: instanceof 是 Java 的一个关键字,用于判断一个对象是否是另一个类或其子类的实例。它的语法形式是:对象 instanceof 类名。 通过使用 instanceof 可以在运行时判断对象的类型。当对象是指定类的实例或者是该类的子类的实例时,返回 true;否则返回 false。 instanceof使用可以用于类型的转换。通常在将一个父类对象赋值给一个子类引用变量时,需要使用 instanceof 进行判断,以确保类型转换的安全性。 当一个对象的变量类型是父类时,可以使用 instanceof 判断其是否是子类的实例,从而避免在进行类型转换时出现 ClassCastException 异常。 在实际应用instanceof 可以用于多态的情况下进行类型的判断。由于子类可以看作是父类的一种扩展,因此父类的对象变量可以引用子类的对象实例。但有时需要检查对象的具体类型,这时就可以使用 instanceof 关键字。 总结起来,instanceof 的作用是判断一个对象是否属于某个类或其子类的实例。它可以用于类型转换和多态的情况下进行类型判断,提高程序的安全性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值