instanceof 實現原理

instanceof

方法說明javascript

判斷指定構造函數的原型對象是否出如今指定對象的原型鏈上

示例java

function Test (name) {
  this.name = name
  this.log = function () {
    console.log(this.name)
  }
}
const t = new Test()

// 判斷對象t是不是另外一個對象(Test)的實例
// 判斷方法就是: Test.prototype是否出如今t的原型鏈上
console.log(t instanceof Test)  // true

源碼函數

// 判斷constructor.prototype是否出如今obj的原型鏈上
function myInstanceof (obj, constructor) {
  // 獲取實例對象obj的原型對象
  let obj__proto__ = obj.__proto__
  while (1) {
    if (obj__proto__ === null) {
      return false
    }
    if (obj__proto__ === constructor.prototype) {
      return true
    }
    obj__proto__ = obj__proto__.__proto__
  }
}

// 示例
function Test (name) {
  this.name = name
  this.log = function () {
    console.log(this.name)
  }
}

const t = new Test('lyn')

console.log(myInstanceof(t, Test))  // true

function A () {}
console.log(myInstanceof(t, A))  // false
相關文章
相關標籤/搜索