当前位置: 首页 > news >正文

js原型链prototype解释

function Person(){}
var person=new Person() 
console.log('======啊啊',Person instanceof Function);//true
console.log('======',Person.__proto__==Function.prototype);//true
console.log('======',Person.prototype.__proto__ === Object.prototype);//true
console.log('======',Function.prototype.__proto__==Object.prototype);//true
var arr=[]
console.log('======',arr.__proto__==Array.prototype);//true
console.log('======',Array.prototype.__proto__==Object.prototype);//true
function Animal() {}
Animal.prototype.eat = function() { console.log("Eating...") };function Dog() {}
Dog.prototype = new Animal(); // Dog 继承 Animal
Dog.prototype.bark = function() { console.log("Bark!") };const myDog = new Dog();
console.log('======',myDog.__proto__.__proto__=== Animal.prototype);//true

上述代码都是true 

理解 JavaScript 中的​​原型链(Prototype Chain)​​是掌握其面向对象编程的核心。原型链的本质是通过对象的隐式原型([[Prototype]],即 __proto__)连接形成的链式结构,用于实现属性和方法的继承。以下是逐步解析:


一、原型链的核心机制

  1. ​每个对象都有一个隐式原型(__proto__)​
    在 JavaScript 中,几乎所有对象(包括函数)都有一个 __proto__ 属性,指向它的构造函数的 prototype 对象。

  2. ​构造函数的 prototype 属性​
    每个函数在创建时会自动生成一个 prototype 属性,它是一个对象,其中默认包含 constructor 属性指向函数自身。例如:

    function Person() {}
    console.log(Person.prototype.constructor === Person); // true

    3.​​实例的原型链形成​
    当通过 new 创建实例时,实例的 __proto__ 会指向构造函数的 prototype 对象:

const person = new Person();
console.log(person.__proto__ === Person.prototype); // true

 ​​4.链式继承​
如果构造函数的 prototype 本身也有 __proto__,则会继续向上查找,直到 Object.prototype,最终指向 null

console.log(Person.prototype.__proto__ === Object.prototype); // true
console.log(Object.prototype.__proto__); // null

原型链的层级关系

function Animal() {}
Animal.prototype.eat = function() { console.log("Eating...") };function Dog() {}
Dog.prototype = new Animal(); // Dog 继承 Animal
Dog.prototype.bark = function() { console.log("Bark!") };const myDog = new Dog();// 原型链层级:
// myDog → Dog.prototype → Animal.prototype → Object.prototype → null
  • myDog 可以访问 bark(来自 Dog.prototype)和 eat(来自 Animal.prototype)。
  • 所有对象最终继承自 Object.prototype,因此 myDog.toString() 可用。

 

 

http://www.xdnf.cn/news/77455.html

相关文章:

  • 利用java语言,怎样开发和利用各种开源库和内部/自定义框架,实现“提取-转换-加载”(ETL)流程的自动化
  • 01.浏览器自动化webdriver源码分析之启动函数
  • 基于Python+Pytest实现自动化测试(全栈实战指南)
  • 热敏电阻的应用说明
  • Rest Client插件写http文件直接发送请求
  • 复盘20250422
  • Maven集成模块打包使用
  • Shell脚本中的字符串截取和规则变化
  • RockChip Android14 修改LCD背光最大值
  • B + 树与 B 树的深度剖析
  • 【通过Docker快速部署Tomcat9.0】
  • ubuntu20.04 远程桌面Xrdp方式
  • 伪谱法求解最优控制问题(附Python代码)
  • 技术与情感交织的一生 (七)
  • K8S节点出现Evicted状态“被驱逐”
  • 【MySQL数据库】表的约束
  • C++学习之游戏服务器开发十四QT登录器实现
  • Ubuntu与OpenHarmony OS 5.0显示系统架构比较
  • 【我的创作纪念日】 --- 与CSDN走过的第365天
  • JavaScript 笔记 --- part 5 --- Web API (part 3)
  • 【后端】构建简洁的音频转写系统:基于火山引擎ASR实现
  • 帕金森发病类型和阶段
  • 深入探讨JavaScript性能瓶颈与优化实战指南
  • 八数码难题
  • C++:STL模板
  • Spark-Streaming
  • Kafka 消息积压监控和报警配置的详细步骤
  • AbMole推荐:CRM197--增强免疫原性,突破疫苗研发困境
  • 网络安全·第五天·TCP协议安全分析
  • SuperMap GIS基础产品FAQ集锦(20250421)