【ES6】js中的__proto__和prototype

在JavaScript中,__proto__和prototype都是用于实现对象继承的关键概念。

1、proto

__proto__是一个非标准的属性,用于设置或获取一个对象的原型。这个属性提供了直接访问对象内部原型对象的途径。对于浏览器中的宿主对象和大多数对象来说,可以使用 obj.proto 访问它们的原型对象。但是,不建议使用这个非标准属性,因为它在未来的标准中可能会被废弃。

例如:

javascript 复制代码
let obj = {};
console.log(obj.__proto__); // [object Object]
2、Prototype

每个JavaScript对象都有一个prototype属性,这个属性是一个指向该对象的原型对象(prototype object)的引用。当一个对象被创建时,它的prototype属性就被设置为其构造函数的prototype属性。这个原型对象自身也有一个prototype属性,这个属性指向的是Object.prototype。

在JavaScript中,所有的对象都是从其原型对象继承的。当访问一个对象的属性或方法时,如果该对象自身没有这个属性或方法,那么JavaScript就会在这个对象的原型对象中查找这个属性或方法,如果原型对象中也没有,那么就会继续在原型对象的原型对象(也就是Object.prototype)中查找。

在JavaScript中,所有函数都有一个prototype属性,这个属性是一个包含一个constructor属性(指向函数自身)和一个proto属性的对象。这个proto属性就是函数的原型对象。

例如:

javascript 复制代码
function MyFunction() { }
console.log(MyFunction.prototype); // [object Object]

总的来说,__proto__和prototype都是用来实现对象继承的,但__proto__是非标准的,建议使用Object.getPrototypeOf()和Object.setPrototypeOf()这样的标准方法来获取和设置一个对象的原型。

相关推荐
宁雨桥9 小时前
深入理解 async/await的原理
前端·javascript·es8
心连欣9 小时前
轮播图实战:用Web API玩转元素属性操作
前端·javascript·api
剑神一笑9 小时前
从 JSON.parse 到树形视图:实现一个在线 JSON 格式化工具
前端·javascript·json
淸湫10 小时前
JavaScript常用正则表达式大全
前端·javascript
最炫的美少女战士10 小时前
claude code 安装报错claude native binary not installed.
javascript
用户23678298016811 小时前
Canvas:实现一个高颜值二维码生成器
javascript
剑神一笑11 小时前
从字符串到时间线:实现一个 Cron 表达式解析器
javascript·typescript·reactjs
❆VE❆12 小时前
基于 contenteditable 实现变量插入富文本编辑器
前端·javascript·vue.js
烤麻辣烫12 小时前
json与fastjson
前端·javascript·学习·json
小陈同学呦12 小时前
JavaScript 深浅拷贝详解
前端·javascript