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 自动作曲、编曲、混音于一体

相关推荐
aqi003 小时前
15天学会AI应用开发(八)使用向量数据库实现RAG功能
人工智能·python·大模型·ai编程·ai应用
Csvn4 小时前
`functools.lru_cache` —— 一行代码搞定缓存加速
后端·python
金銀銅鐵21 小时前
[Python] 从《千字文》中随机挑选汉字
后端·python
cup111 天前
[技术复盘] Windows Python 打包实战:Nuitka 环境踩坑总结与 CI 自动化构建全指南
python·ai·环境变量·ci·nuitka·skill
aqi001 天前
15天学会AI应用开发(七)有了大模型为什么还要引入RAG
人工智能·python·大模型·ai编程·ai应用
金銀銅鐵1 天前
用 Python 实现 Take-Away 游戏
python·游戏
copyer_xyf1 天前
Agent 流程编排
后端·python·agent
copyer_xyf1 天前
Agent RAG
后端·python·agent