Get to know MDN better
このページはコミュニティーの尽力で英語から翻訳されました。MDN Web Docs コミュニティーについてもっと知り、仲間になるにはこちらから。
This feature is well established and works across many devices and browser versions. It’s been available across browsers since 2016年9月.
Reflect.construct() は静的メソッドで、new 演算子のように、ただし関数として動作します。これは new target(...args) の呼び出しと同等です。さらに、別の new.target 値を指定することもすることができます。
呼び出し対象の関数。
argumentsListtarget を呼び出す際の引数を指定する配列風オブジェクト。
newTarget 省略可target 内の new.target 式の値。デフォルトは target です。一般的に(例を参照)、target はオブジェクトを初期化するロジックを指定し、newTarget.prototype は構築されたオブジェクトのプロトタイプを指定します。
target (または、もしあれば newTarget) の新しいインスタンスで、 target に argumentsList を渡してコンストラクターとして呼び出すことで初期化します。
target または newTarget がコンストラクターではない場合、または argumentsList がオブジェクトではない場合に発生します。
Reflect.construct() はコンストラクター呼び出しの反射的意味づけを提供します。つまり、Reflect.construct(target, argumentsList, newTarget) は意味的に次のものと同等です。
new 演算子を使用する場合、target と newTarget は常に同じコンストラクターであることに注意してください。ただし、Reflect.construct() を使用すると、異なる new.target 値を渡すことが可能です。概念的には、newTarget は new が呼び出された関数であり、newTarget.prototype が構築されたオブジェクトのプロトタイプとなります。一方、target はオブジェクトを初期化するために実際に実行されるコンストラクターです。例えば、クラス継承において new.target は現在実行中のコンストラクターとは異なる場合もあります。
Reflect.construct() によって、可変長引数を指定してコンストラクターを呼び出すことができます。(これは通常のコンストラクター呼び出しでスプレッド構文を組み合わせて使用することでも可能です。)
Reflect.construct() は target の [[Construct]] オブジェクト内部メソッドを呼び出します。
newTarget が渡された場合、コンストラクター内で new.target の値を変更します。生成されるオブジェクトは target ではなく newTarget のインスタンスとなります。
もちろん、構築されたオブジェクトのプロトタイプチェーンについては、コンストラクターの実装に依存するため、確固たる保証はありません。例えば、target コンストラクターがオブジェクトを返す場合、newTarget の値に関わらず、そのオブジェクトが構築されたオブジェクトとなります。target が construct トラップを持つプロキシーである場合、そのトラップが構築プロセスを完全に制御します。
有効な new.target は、prototype プロパティを持つコンストラクター関数であるべきですが、後者は強制されません。prototype プロパティの値がオブジェクトでない場合、初期化されたオブジェクトは Object.prototype から継承します。
Reflect が導入される前は、オブジェクトを構築するのにコンストラクターとプロトタイプの任意の組み合わせで Object.create() を使用して構築することができました。
この 2 つの手法の最終結果は同じですが、その過程に重要な違いがあります。 Object.create() と Function.prototype.apply() を使用する場合、 new.target 演算子はコンストラクター内で undefined を返します。これは、 new 演算子を用いないためです。(実際には、apply の意味づけを使用しており、construct ではありません。ただし、通常の関数はほぼ同じように動作します。)
一方、 Reflect.construct() を呼び出す場合は、 new.target 演算子は、提供されていれば newTarget を指し、そうでなければ target を指します。
| ECMAScript® 2027 Language Specification # sec-reflect.construct |
Enable JavaScript to view this browser compatibility table.
This page was last modified on 2026年3月5日 by MDN contributors.
Your blueprint for a better internet.
Visit Mozilla Corporation’s not-for-profit parent, the Mozilla Foundation.
Portions of this content are ©1998–2026 by individual mozilla.org contributors. Content available under a Creative Commons license.