当前位置:首页 > 行业动态 > 正文

js in运算符

JavaScript中的in运算符用于检查对象是否具有指定的属性。

在JavaScript中,instanceof运算符用于检测构造函数的prototype属性是否出现在某个实例对象的原型链上,当一个对象从某个构造函数创建时,它的原型链上会有一个指向该构造函数的prototype属性,我们可以通过检查实例对象的原型链来确定它是否属于某个特定的构造函数。

js in运算符  第1张

基本用法

instanceof运算符的基本语法如下:

object instanceof constructor 

object是要检查的对象,constructor是构造函数,如果object的原型链上有一个指向constructor.prototype的属性,那么表达式的结果为true,否则为false。

我们有一个名为Person的构造函数:

function Person(name, age) {
  this.name = name;
  this.age = age;
} 

我们可以创建一个Person类型的对象,并使用instanceof运算符来检查它是否属于Person构造函数:

const person = new Person('张三', 30);
console.log(person instanceof Person); // 输出:true 

与typeof的区别

typeof运算符用于获取一个变量或对象的类型,它不能区分对象的具体类型,只能返回一些基本的字符串值,如'number'、'string'、'undefined'等,而instanceof运算符可以准确地判断对象是否属于某个特定的构造函数。

我们有一个名为Animal的构造函数:

function Animal() {
  // ...
} 

我们可以创建一个继承自Animal的子类Dog:

function Dog() {
  Animal.call(this);
}
Dog.prototype = Object.create(Animal.prototype);
Dog.prototype.bark = function() {
  console.log('汪汪汪');
}; 

现在,我们可以创建一个Dog类型的对象,并使用typeof和instanceof运算符来检查它:

const dog = new Dog();
console.log(typeof dog); // 输出:'object'(不准确)
console.log(dog instanceof Dog); // 输出:true(准确)
console.log(dog instanceof Animal); // 输出:true(准确) 

多层继承的处理

在多层继承的情况下,我们需要确保正确地处理原型链,我们有一个名为Animal的基类,以及一个名为Mammal的子类,它继承自Animal,我们有一个名为Dog的子类,它继承自Mammal,在这种情况下,我们可以使用instanceof运算符来检查一个对象是否属于某个特定的构造函数。

function Animal() {
  // ...
}
function Mammal() {
  Animal.call(this);
}
Mammal.prototype = Object.create(Animal.prototype);
Mammal.prototype.breathe = function() {
  console.log('呼吸');
};
function Dog() {
  Mammal.call(this);
}
Dog.prototype = Object.create(Mammal.prototype);
Dog.prototype.bark = function() {
  console.log('汪汪汪');
}; 

现在,我们可以创建一个Dog类型的对象,并使用instanceof运算符来检查它:

const dog = new Dog();
console.log(dog instanceof Dog); // 输出:true(准确)
console.log(dog instanceof Mammal); // 输出:true(准确)
console.log(dog instanceof Animal); // 输出:true(准确) 

注意事项

1、instanceof运算符只能用于对象,不能用于基本类型(如数字、字符串、布尔值等),对于基本类型,它会返回false。

“`javascript

const num = 42;

console.log(num instanceof Number); // 输出:false(基本类型)

“`

0