JavaScript中类属性与原型属性的覆盖规则详解

实例属性优先于原型属性访问,类字段声明本质是实例属性,static属性属于类本身而非原型链。在 JavaScript 中,类属性(即直接定义在类体内的 实例属性)和原型属性(即定义在类的 prototype 上的方法或通过 static 定义的静态成员)遵循明确的属性访问与覆盖逻辑。理解它们的优先级、作用域和赋值行为,是避免"方法不生效""属性看似被修改却没变"等常见问题的关键。实例属性优先于原型属性访问当通过实例访问一个属性或方法时,JavaScript 引擎会按以下顺序查找:先检查实例自身是否拥有该属性(即在 this 上直接定义,如类字段初始化 value = 123 或构造函数中 this.value = ...) 若不存在,则沿 proto 链向上查找,在 Constructor.prototype 上找(例如类中定义的 method() {}) 再往上是 Object.prototype,最后到 null这意味着:即使原型上已有同名方法,只要你在实例上直接赋值(obj.name = 'xxx'),后续访问 obj.name 就永远取实例值,不再查原型------这是"覆盖"的实质:不是删除原型属性,而是遮蔽(shadowing)。类字段声明(public field)本质是实例属性ES2022 起支持的类字段语法(如 count = 0)会在每次构造函数执行时,为每个实例创建独立副本:立即学习"Java免费学习笔记(深入)";class Counter { count = 0; // ? 每个实例都有自己的 count inc() { this.count++; }}const a = new Counter();const b = new Counter();a.inc(); console.log(a.count); // 1console.log(b.count); // 0 ------ 互不影响这类属性不会出现在原型上,Counter.prototype.hasOwnProperty('count') 返回 false。它和在构造函数中写 this.count = 0 效果一致,只是更简洁。 唱鸭 音乐创作全流程的AI自动作曲工具,集 AI 辅助作词、AI 自动作曲、编曲、混音于一体

相关推荐
2301_817672262 小时前
如何修改Oracle服务器的主机名_listener和tnsnames同步调整
jvm·数据库·python
snow@li10 小时前
数据库:市场中都有哪些数据库 / 优缺点 使用情况
数据库
kishu_iOS&AI10 小时前
深度学习 —— 损失函数
人工智能·pytorch·python·深度学习·线性回归
好运的阿财10 小时前
OpenClaw工具拆解之canvas+message
人工智能·python·ai编程·openclaw·openclaw工具
wengqidaifeng10 小时前
python启航:1.基础语法知识
开发语言·python
NoSi EFUL10 小时前
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
android·数据库·mysql
观北海10 小时前
Windows 平台 Python 极简 ORB-SLAM3 Demo,从零实现实时视觉定位
开发语言·python·动态规划
河阿里10 小时前
SQL数据库:五大范式(NF)
数据库·sql·oracle
FreakStudio10 小时前
做了个Claude Code CLI 电子宠物:程序员的实体监工代码搭子
python·单片机·嵌入式·面向对象·并行计算·电子diy·电子计算机