如何通过链式记忆理解__proto__的原理?

2026-06-09 08:422阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计277个文字,预计阅读时间需要2分钟。

如何通过链式记忆理解__proto__的原理?

简化修改后内容:

实例化解析:javascriptfunction Foo() {}

var foo=new Foo();foo.__proto__=Foo.prototype;foo.__proto__.__proto__=Object.prototype;

实例化解析:functionFoo(){};varfoonewFoo();foo.__proto__Foo.prototype;foo.__proto__.__proto__

实例化解析:

function Foo() {};var foo = new Foo();foo.__proto__ === Foo.prototype;foo.__proto__.__proto__ === Object.prototype;foo.__proto__.__proto__.__proto__ === null;foo.prototype === undefined;foo.toString === Object.prototype.toString;

原形继承后的实例化解析:

function Bar() {};Bar.prototype.__proto__ = Foo.prototype;var bar = new Bar();bar.__proto__ === Bar.prototype;bar.__proto__.__proto__ === Foo.prototype;bar.__proto__.__proto__.__proto__ === Object.prototype;bar.__proto__.__proto__.__proto__.__proto__ === null;bar.prototype === undefined;bar.toString === Object.prototype.toString

对象bar,访问toString,整个链式过程如下:

bar.toString || bar.__proto__.toString || bar.__proto__.__proto__.toString || bar.__proto__.__proto__.__proto__.toString bar.toString === Object.prototype.toString

最终调用的是 Object.prototype.toString

如何通过链式记忆理解__proto__的原理?

奇怪的Foo.toString

Foo.__proto__ === Function.prototype;Foo.__proto__.__proto__ === Object.prototype;Foo.prototype.__proto__ === Object.prototype;// 神奇竟然不等于 Object.prototype.toStringFoo.toString === Object.toString;Foo.prototype.toString === Object.prototype.toString;

每个function生成的时候都直接被设置了toString 等于 Object.toString了。

参考文档

  • 實體關係的確定
  • A re-introduction to Javascript

有爱

希望本文对你有用 ^_^

本文共计277个文字,预计阅读时间需要2分钟。

如何通过链式记忆理解__proto__的原理?

简化修改后内容:

实例化解析:javascriptfunction Foo() {}

var foo=new Foo();foo.__proto__=Foo.prototype;foo.__proto__.__proto__=Object.prototype;

实例化解析:functionFoo(){};varfoonewFoo();foo.__proto__Foo.prototype;foo.__proto__.__proto__

实例化解析:

function Foo() {};var foo = new Foo();foo.__proto__ === Foo.prototype;foo.__proto__.__proto__ === Object.prototype;foo.__proto__.__proto__.__proto__ === null;foo.prototype === undefined;foo.toString === Object.prototype.toString;

原形继承后的实例化解析:

function Bar() {};Bar.prototype.__proto__ = Foo.prototype;var bar = new Bar();bar.__proto__ === Bar.prototype;bar.__proto__.__proto__ === Foo.prototype;bar.__proto__.__proto__.__proto__ === Object.prototype;bar.__proto__.__proto__.__proto__.__proto__ === null;bar.prototype === undefined;bar.toString === Object.prototype.toString

对象bar,访问toString,整个链式过程如下:

bar.toString || bar.__proto__.toString || bar.__proto__.__proto__.toString || bar.__proto__.__proto__.__proto__.toString bar.toString === Object.prototype.toString

最终调用的是 Object.prototype.toString

如何通过链式记忆理解__proto__的原理?

奇怪的Foo.toString

Foo.__proto__ === Function.prototype;Foo.__proto__.__proto__ === Object.prototype;Foo.prototype.__proto__ === Object.prototype;// 神奇竟然不等于 Object.prototype.toStringFoo.toString === Object.toString;Foo.prototype.toString === Object.prototype.toString;

每个function生成的时候都直接被设置了toString 等于 Object.toString了。

参考文档

  • 實體關係的確定
  • A re-introduction to Javascript

有爱

希望本文对你有用 ^_^