JS中的prototype、__proto__与constructor

简介: JS中的prototype、__proto__与constructor

13.png

简单实例

// 定义一个函数
function Foo(name) {
    this.name = name
}

// 调用函数 这个函数返回 undefined
var foo = Foo('Tom')
console.log(foo); // undefined


// 调用构造方法
console.log(Foo); // [Function: Foo]
console.log(Foo.__proto__); // [Function]
console.log(Foo.constructor); // [Function: Function]

console.log(Foo.prototype); // Foo {}
console.log(Foo.prototype.__proto__); // {}
console.log(Foo.prototype.constructor); // [Function: Foo]

console.log(Foo.prototype.constructor === Foo); // true

// 相当于 Foo.prototype.constructor('Tom') 返回this
foo = new Foo('Tom')
console.log(foo); // Foo { name: 'Tom' }
console.log(foo.__proto__); // Foo {}
console.log(foo.prototype); // undefined
console.log(foo.constructor); // [Function: Foo]


var foo1 = new Foo.prototype.constructor('Tom')
console.log(foo1); // Foo { name: 'Tom' }

var foo2 = new Foo('Tom')
console.log(foo2); // Foo { name: 'Tom' }

console.log(foo1 == foo2); // false

console.log(foo1.__proto__); // Foo {}
console.log(foo1.prototype); // undefined
console.log(foo1.constructor); // [Function: Foo]

console.log(foo2.__proto__); // Foo {}
console.log(foo2.prototype); // undefined
console.log(foo2.constructor); // [Function: Foo]

总结

属性

归属

作用

指向

顶端

__proto__

对象所独有

对象属性的查找路径

对象->对象

原型链顶端null

constructor

对象所独有

构造函数

对象->函数

Function

prototype

函数所独有

所有实例共享的属性和方法

函数->对象

-

图片来源和文章参考

帮你彻底搞懂JS中的prototype、__proto__与constructor(图解)

            </div>
目录
相关文章
|
数据采集 JSON 关系型数据库
将 MySQL 数据抽取并写入 DataHub,您可以按照以下步骤进行
将 MySQL 数据抽取并写入 DataHub,您可以按照以下步骤进行
862 2
|
JSON Java fastjson
java小工具util系列3:JSON和实体类转换工具
java小工具util系列3:JSON和实体类转换工具
321 2
|
人工智能 监控 5G
5G 网络切片的动态管理:实现灵活高效的网络资源分配
5G 网络切片的动态管理:实现灵活高效的网络资源分配
737 1
|
安全 生物认证 网络安全
双重身份验证:数字安全的坚固防线
【8月更文挑战第31天】
1130 1
|
机器学习/深度学习 算法 程序员
《零基础实践深度学习》波士顿房价预测任务 02
这篇文章通过"波士顿房价预测"任务,介绍了使用Python和Numpy构建神经网络模型的基本思路和操作,首先以线性回归模型为例,解释了神经网络中损失函数的选择和模型的构建过程。
|
数据采集 传感器 存储
数据采集
【6月更文挑战第16天】数据采集。
488 12
|
数据采集 存储 数据挖掘
构建高效Web爬虫:Python与BeautifulSoup实战指南
【8月更文挑战第31天】本文将引导读者步入Web爬虫的世界,通过Python编程语言和BeautifulSoup库的强强联手,解锁数据抓取的艺术。文章不仅提供代码示例,还将深入探讨如何设计高效、可维护且符合伦理的爬虫程序。
|
Java 开发工具 Android开发
Android Studio利用Build.gradle导入Git commit ID、Git Branch、User等版本信息
本文介绍了在Android Studio项目中通过修改`build.gradle`脚本来自动获取并添加Git的commit ID、branch名称和用户信息到BuildConfig类中,从而实现在编译时将这些版本信息加入到APK中的方法。
528 0
|
SQL 数据可视化 安全
宝塔面板使用`Navicat`或其他工具连接数据库
Linux如果想要自己配置环境,多多少少还是有些麻烦,于是大部分的用户会选择为没有界面的Linux安装一个可视化面板,宝塔面板一切都会帮你完成,但是有时候,我们想要用SQL管理工具连接数据库时,我们却连接不上去。
577 0
|
供应链 Cloud Native 数据管理
云计算在企业数字化转型中的关键作用及最佳实践
云计算重塑企业数字化转型,提供弹性、可扩展的计算平台,降低成本,提升运营效率和客户体验。其优势包括成本效益、灵活性、高可用性及创新加速。企业应制定云计算战略,开发云原生应用,采用混合云架构,并注重数据安全与合规。案例中,一制造企业通过云计算实现全球业务统一,简化供应链,加速产品创新,优化生产并保障数据安全。