先给出一个例子
function Fn(){}; var fn = new Fn(); console.log(fn instanceof Fn);//true console.log(fn instanceof Object);//true
看下instanceof运算符的判断规则,
语言规范中对instanceof的定义看起来比较繁琐,不过用js代码来表示就很容易懂了
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__; } }
根据以上规则,可以解释很多奇怪的现象:
console.log(Object instanceof Function); //true console.log(Function instanceof Object); //true console.log(Function instanceof Function); //true
结合原型一文中的原型关系图和instanceof的判断规则,就能了解这些表达式为什么是true
instanceof这样设计,是想表达A与B一种什么关系呢? 那就是继承或者说原型链