instanceof运算符

https://www.ibm.com/developer...

根据此文

instaceof可以用下列代码模拟

function instance_of(L, R) {//L 表示左表达式,R 表示右表达式
  var O = R.prototype;// 取 R 的显示原型
  L = L.__proto__;// 取 L 的隐式原型
  while (true) { 
    if (L === null) 
      return false; 
    if (O === L)// 这里重点:当 O 严格等于 L 时,返回 true 
      return true; 
    L = L.__proto__; 
  } 
 }
     

但是
var a=1;
instance_of(a,Object)为true
a instanceof Object却返回false,这是为什么?

阅读 2.4k
3 个回答

楼主,你可以试一试 你的 instance_of 是代替不了 instanceof

首先,明确你的样本 a 是Number 类型

但是,执行结果如下
instance_of(a, Object) // true
instance_of(a, Number) // true

修改 instance_of 方法:

function instance_of(L, R) {
  try {
    var O = R.prototype;// 取 R 的显示原型
    L = Object.getPrototypeOf(L);// 取 L 的隐式原型
    while (true) { 
      if (L === null) 
        return false; 
      if (O === L)// 这里重点:当 O 严格等于 L 时,返回 true 
        return true; 
      L = L.Object.getPrototypeOf(L); 
    }
  } catch (e) {
    return false
  }
}

再次实验:

var a = 1

instance_of(a, Object) // false 
instance_of(a, Number) // true

var parent = function () {}  
var child = new parent()

instance_of(child, parent) // true

这个文章中用的标准是ES3的

ES6的instanceof标准更长一点, 规定了当type(L)不是Object时L instanceof R 应当返回false. 这个模拟代码不适用

有一部分是原型链的内容,在你的模拟代码中:

    function instance_of(L, R) {//L 表示左表达式,R 表示右表达式
      var O = R.prototype;// 取 R 的显示原型
      L = L.__proto__;// 取 L 的隐式原型
      while (true) { 
        if (L === null) 
          return false; 
        if (O === L)// 这里重点:当 O 严格等于 L 时,返回 true 
          return true; 
          L = L.__proto__; 
       } 
     }

L = L._proto_ 代表着L会沿着原型链一直向上查找原型,而在本例中,最后是从Number包装对象==>Object对象,而R就是Object,再经过全等运算符之后就返回true,所以instance_of(a,Object)为true。

a instanceof Object返回false,是因为它不会经过原型链查找,直接就是Number对象的实例与Object的判断,所以结果为false

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题