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

相关推荐
睡不醒男孩0308232 小时前
第七篇:揭秘 PostgreSQL 数据库内核级管控:CLup 深度架构设计与高可用底座技术白皮书
数据库·postgresql·clup
无风听海2 小时前
多租户系统中的 OIDC:Discovery 端点与联合登录的深度实践
后端·python·flask
cmes_love2 小时前
Level 2逐笔成交历史数据下载方法笔记
数据库·笔记·oracle
CTA终结者2 小时前
期货量化主力换月程序怎么移仓:天勤 underlying_symbol 与任务切换
python·区块链
马士兵教育3 小时前
Java还有前景吗?Java+AI大模型学习路线及项目?
java·人工智能·python·学习·机器学习
swordbob3 小时前
MySQL字符集陷阱:从Oracle迁移踩坑到utf8mb4强制规范
数据库·sql
牛油果子哥q3 小时前
【C++ STL string 】C++ STL string 终极精讲:底层原理、内存机制、全套API、深浅拷贝、易错坑点与工程实战规范
数据库·c++
KaMeidebaby3 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
十五年专注C++开发3 小时前
MySql中各种功能用sql语句实现总结
数据库·sql·mysql
Cloud_Shy6183 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第五章 Item 30 - 32)
开发语言·人工智能·笔记·python·学习方法