<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
</head>
<body>
<script>
function myInstanceOf(left, right) {
// 首先,正常而言,A instanceof B
//我们是要判断 B 的原型是否在 A 的原型链上
// 所以,我们要获取 A 的原型链,获取 B 的原型
leftProto = left.__proto__
rightPrototype = right.prototype
// 接下来就是判断,如果一次判断未成功,那么就一直沿着原型链查找知道返回值结束判断
while (true) {
// 首先判断 leftproto 是否为空
// __proto__为空的只有Object的原型对象,它是原型链的终点
// 意思是,如果查找到原型链的终点了还没有返回结果,那么 B 就不在 A 的原型链上
if (leftProto === null) return false
// 相等,则在原型链上
if (leftProto === rightPrototype) return true
// 如果不满足这两个判断结束的情况,就会沿着原型链
leftProto = leftProto.__proto__
}
}
function sum() {
}
var obj = new Object()
console.log(myInstanceOf(obj, Object)); //true
console.log(myInstanceOf(sum, Array)); //false
</script>
</body>
</html>
instanceof 原理详解
猜你喜欢
转载自blog.csdn.net/qq_45382872/article/details/125989782
今日推荐
周排行