検索
ホームページウェブフロントエンドjsチュートリアルJavascript_11_constructor 実装原理_JavaScript スキルの理解

コンストラクターとは

簡単に理解すると、コンストラクターはオブジェクトのコンストラクターを指します。次の例を参照してください。

コードをコピー コードは次のとおりです。

function Foo( ){};
var foo = new Foo();
alert(foo.constructor);//Foo
alert(Foo.constructor);//関数
alert(Object.constructor) ;//Function
alert(Function.constructor);//Function

foo.constructor が Foo の場合、foo のコンストラクターが Foo なのでわかりやすいと思います。 Foo、Object、Function のコンストラクターが Function であるという事実については、何も議論の余地はないと思います。 (Foo、Object、Function はすべて関数オブジェクトであり、すべての関数オブジェクトは Function オブジェクトから構築されるため、コンストラクターは Function です。詳細は「js_Function オブジェクト」を参照してください。)

の関係プロトタイプとコンストラクター

コードをコピー コードは次のとおりです。

function Dog( ) {}
alert(Dog === Dog.prototype.constructor);//true

JavaScript では、各関数には「prototype」という名前の属性があり、これは、プロトタイプオブジェクト。このプロトタイプ オブジェクトには、関数自体を参照する「コンストラクター」と呼ばれるプロパティがあります。これは図に示すように循環参照です:
Javascript_11_constructor 実装原理_JavaScript スキルの理解
コンストラクター属性はどこから来たのでしょうか?
文字列を構築する関数の構築プロセスを見てみましょう:
Javascript_11_constructor 実装原理_JavaScript スキルの理解
注: 関数コンストラクター どの関数オブジェクトのプロセスも同じであるため、文字列、ブール値、数値などの組み込みオブジェクトであっても、ユーザー定義オブジェクトであっても、構築プロセスは上図と同じです。ここでの文字列はあくまで代表です!
図からわかるように、コンストラクターは Function が関数オブジェクトを作成するときに生成されます。「プロトタイプとコンストラクターの関係」で説明したように、コンストラクターは関数オブジェクトのプロトタイプ チェーン内の属性です。それは String=== String.prototype.constructor です。

また、コードの一部を使用して、理論が正しいことを証明したいと思います。
コードをコピーしますコードは次のとおりです:

function person(){}
var p = new Person();
alert(p.constructor);//person
alert( Person.prototype.constructor) ;//パーソン
alert(person.prototype.hasOwnProperty('constructor'));//true
alert(person.prototype.isPrototypeOf(p));//true
alert(Object.prototype .isPrototypeOf(p));//true
alert(person.prototype == Object.prototype);//false

今では、次のことがわかります。これは前の「プロトタイプ チェーン」と同じです。「実装原則」のデフォルトのプロトタイプは Object.prototype を指しますが、明らかに当時の理論はあまり包括的ではありませんでした。

特別なオブジェクト
注意深い読者はこの質問をするかもしれませんが、あなたの理論はオブジェクトには当てはまりません。次のコードは上記の理論と矛盾するためです:
コードをコピー コードは次のとおりです:

alert(Object.prototype.hasOwnProperty('constructor'));//true
alert(Object.prototype.hasOwnProperty('isPrototypeOf'));//true、上記の理論によれば、ここでは false が返されるはずです

本当にそうですか?いいえ!次に、特別なオブジェクトがどのように処理されるかを見てみましょう:
Javascript_11_constructor 実装原理_JavaScript スキルの理解
この図の原理は、上の図の原理と同じであることがわかります。これは、Object.prototype.hasOwnProperty('isPrototypeOf') が true であることを正しく説明できます。

コンストラクター探索
コードをコピー コードは次のとおりです。

function Animal(){}
function person(){}
var person = new Person();
alert(person. constructor); //person

前のセクションの内容に基づいて、このコードの結果を正しく理解できますか?それについて考えた後、その記憶表現を見てください:
Javascript_11_constructor 実装原理_JavaScript スキルの理解
この図は、関数が動物と人を構築するプロセスを明確に示しています。同時にインスタンス人物と人物との関係も表示されます。

もう少し詳しく見てみると、コードは次のとおりです。
コードをコピーします コードは次のとおりです。

function Animal(){}
function Person(){}
Person.prototype = new Animal();
var person = new Person();
alert(person .constructor); //Animal

At this time, the constructor of person becomes Animal. How to explain?
Javascript_11_constructor 実装原理_JavaScript スキルの理解
Note: The dotted line in the picture represents the default prototype pointer of Person (for reference only). But we pointed Person.prototype to new Animal.
At this time, the prototype of Person points to the instance of Animal, so the constructor of person is the constructor of Animal.

Conclusion: The principle of constructor is very simple, which is to look for the constructor attribute on the prototype chain of the object.

Note: If you cannot correctly understand the content of this article, please review the content of the previous chapters.
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
深入了解Kafka消息队列的底层实现机制深入了解Kafka消息队列的底层实现机制Feb 01, 2024 am 08:15 AM

Kafka消息队列的底层实现原理概述Kafka是一个分布式、可扩展的消息队列系统,它可以处理大量的数据,并且具有很高的吞吐量和低延迟。Kafka最初是由LinkedIn开发的,现在是Apache软件基金会的一个顶级项目。架构Kafka是一个分布式系统,由多个服务器组成。每个服务器称为一个节点,每个节点都是一个独立的进程。节点之间通过网络连接,形成一个集群。K

PHP核心的运行机制与实现原理详解PHP核心的运行机制与实现原理详解Nov 08, 2023 pm 01:15 PM

PHP是一种流行的开源服务器端脚本语言,大量被用于Web开发。它能够处理动态数据以及控制HTML的输出,但是,如何实现这一切?那么,本文将会介绍PHP的核心运行机制和实现原理,并利用具体的代码示例,进一步说明其运行过程。PHP源码解读PHP源码是一个由C语言编写的程序,经过编译后生成可执行文件php.exe,而对于Web开发中使用的PHP,在执行时一般通过A

PHP中的粒子群算法实现原理PHP中的粒子群算法实现原理Jul 10, 2023 pm 11:03 PM

PHP中的粒子群算法实现原理粒子群算法(ParticleSwarmOptimization,PSO)是一种优化算法,常用于求解复杂的非线性问题。它通过模拟鸟群觅食行为,以寻找最优解。在PHP中,我们可以利用PSO算法快速求解问题,本文将介绍其实现原理,并给出相应的代码示例。粒子群算法基本原理粒子群算法的基本原理是通过迭代搜索找到最优解。算法中存在一群粒

深入分析Kafka消息队列的技术原理与适用场景深入分析Kafka消息队列的技术原理与适用场景Feb 01, 2024 am 08:34 AM

Kafka消息队列的实现原理Kafka是一个分布式发布-订阅消息系统,它可以处理大量的数据,并且具有很高的可靠性和可扩展性。Kafka的实现原理如下:1.主题和分区Kafka中的数据存储在主题(topic)中,每个主题可以分为多个分区(partition)。分区是Kafka中最小的存储单位,它是一个有序的、不可变的日志文件。生产者将数据写入主题,而消费者从

刨析swoole异步任务处理功能的实现原理刨析swoole异步任务处理功能的实现原理Aug 05, 2023 pm 04:15 PM

刨析swoole异步任务处理功能的实现原理随着互联网技术的迅猛发展,各种问题的处理变得越来越复杂。在Web开发中,处理大量的请求和任务是一个常见的挑战。传统的同步阻塞方式无法满足高并发的需求,于是异步任务处理成为一种解决方案。Swoole作为PHP协程网络框架,提供了强大的异步任务处理功能,本文将以一个简单的示例来解析其实现原理。在开始之前,我们需要先确保已

掌握Tomcat中间件底层工作机制掌握Tomcat中间件底层工作机制Dec 28, 2023 pm 05:25 PM

理解Tomcat中间件的底层实现原理,需要具体代码示例Tomcat是一个开源的、使用广泛的JavaWeb服务器和Servlet容器。它具有高度的可扩展性和灵活性,常用于部署和运行JavaWeb应用程序。为了更好地理解Tomcat中间件的底层实现原理,我们需要探究它的核心组件和运行机制。本文将通过具体的代码示例,解析Tomcat中间件的底层实现原理。Tom

Java爬虫技术的原理:详细剖析网页数据抓取过程Java爬虫技术的原理:详细剖析网页数据抓取过程Jan 09, 2024 pm 02:46 PM

深入解析Java爬虫技术:网页数据抓取的实现原理引言:随着互联网的快速发展和信息爆炸式增长,大量的数据被存储在各种网页上。这些网页数据对于我们进行信息提取、数据分析和业务发展非常重要。而Java爬虫技术则是一种常用的网页数据抓取方式。本文将深入解析Java爬虫技术的实现原理,并提供具体的代码示例。一、什么是爬虫技术爬虫技术(WebCrawling)又称为网

C语言中乘方运算的实现原理C语言中乘方运算的实现原理Feb 20, 2024 pm 09:57 PM

C语言中乘方运算的实现原理在C语言中,乘方运算是计算一个数的n次方,即计算x^n的结果。虽然C语言本身没有提供直接的乘方运算符,但可以通过循环或递归等方法来实现乘方运算。一、循环法实现乘方运算循环法是一种比较常用的实现乘方运算的方法,其基本思想是通过多次循环累乘来计算结果。示例代码如下:#includedoublepow

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません