前端面试题每日一练,测测你对JavaScript原型继承和 instanceof 的理解

今天的挑战题目涉及到JavaScript中的原型继承和 instanceof 操作符的使用。我们将通过分析一个关于构造函数和原型链的例子,来探索对象继承的机制,以及如何判断对象的类型。让我们一起深入解析这段代码,看看它会输出什么以及为什么。

代码解析

首先,代码定义了两个构造函数 ShapeCircle

go 复制代码
function Shape() {}
function Circle(radius) {}
  • Shape 是一个简单的构造函数,目前它不执行任何操作。

  • Circle 是一个构造函数,它接受一个参数 radius,但目前也没有执行任何操作。

接下来,代码通过 Object.create 设置了 Circle.prototype 的原型:

go 复制代码
Circle.prototype = Object.create(Shape.prototype);
  • 这行代码的作用是让 Circle 的原型 (Circle.prototype) 继承自 Shape 的原型 (Shape.prototype)。

  • 这意味着通过 new Circle() 创建的对象,它的原型链上会包含 Shape.prototype,即 CircleShape 的子类。

然后,代码创建了一个 Shape 类型的对象:

go 复制代码
const shape = new Shape();
  • 这里我们使用 new Shape() 创建了一个对象 shape。它的原型是 Shape.prototype

最后,代码使用 instanceof 操作符来检查 shape 是否是 Circle 的实例:

go 复制代码
console.log(shape instanceof Circle);

理解 instanceof

instanceof 操作符用于检测某个对象是否是某个构造函数的实例。其工作原理是检查对象的原型链上是否存在该构造函数的 prototype 属性。

在这个例子中:

  • shape 对象的原型链是 Shape.prototype

  • Circle.prototype 的原型是 Shape.prototype

但是,shape 对象的原型链并不直接包含 Circle.prototype,而是直接指向 Shape.prototype,因此:

  • shape instanceof Circle 会返回 false,因为 shape 的原型链中不包括 Circle.prototype

输出结果

根据上述分析,最终的输出结果是:

go 复制代码
console.log(shape instanceof Circle); // 输出 false

结束

这道题目展示了JavaScript中的原型继承和 instanceof 操作符的工作原理。尽管 Circle 的原型链中包含 Shape.prototype,但反过来检查 Shape 的实例是否属于 Circle 并不会成立。理解原型链的层次关系对于正确解答这道题目至关重要。你答对了吗?欢迎在评论区分享你的答案和见解!

每天一道面试题,帮助你提高编程技能,不断进步!记得关注哦!

相关推荐
wangqiaowq2 小时前
StarRocks安装部署测试
java·开发语言
Jonathan Star6 小时前
沉浸式雨天海岸:用A-Frame打造WebXR互动场景
前端·javascript
缺点内向6 小时前
C#: 高效移动与删除Excel工作表
开发语言·c#·.net·excel
工业甲酰苯胺6 小时前
实现 json path 来评估函数式解析器的损耗
java·前端·json
老前端的功夫6 小时前
Web应用的永生之术:PWA落地与实践深度指南
java·开发语言·前端·javascript·css·node.js
LilySesy7 小时前
ABAP+WHERE字段长度不一致报错解决
java·前端·javascript·bug·sap·abap·alv
ᐇ9597 小时前
Java HashMap深度解析:数据结构、原理与实战指南
java·开发语言·数据结构
QT 小鲜肉8 小时前
【个人成长笔记】在 Linux 系统下撰写老化测试脚本以实现自动压测效果(亲测有效)
linux·开发语言·笔记·单片机·压力测试
Wang's Blog8 小时前
前端FAQ: Vue 3 与 Vue 2 相⽐有哪些重要的改进?
前端·javascript·vue.js
程序员龙一8 小时前
C++之static_cast关键字
开发语言·c++·static_cast