ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript の継承のために new ではなく Object.create を選択するのはどのような場合ですか?

JavaScript の継承のために new ではなく Object.create を選択するのはどのような場合ですか?

Linda Hamilton
リリース: 2024-11-19 07:11:03
オリジナル
979 人が閲覧しました

When to Choose Object.create Over new for JavaScript Inheritance?

JavaScript の継承: Object.create と new

JavaScript の継承の概念は、実現するにはさまざまなアプローチがあるため、混乱を招く可能性があります。それ。この記事の目的は、最も受け入れられているメソッドを明確にし、特定のシナリオに対する解決策を提供することです。

Object.create と new について

Object.create は、既存のオブジェクトを継承して新しいオブジェクトを作成します。これは、基本オブジェクトを作成し、それを追加のプロパティとメソッドで拡張する場合に便利です。 Object.create の構文は次のとおりです。

Object.create(prototype[, propertiesObject])
ログイン後にコピー

一方、 new キーワードは、オブジェクトの新しいインスタンスを作成し、そのコンストラクター関数を呼び出すために使用されます。 new の構文は次のとおりです。

new ConstructorFunction([arguments])
ログイン後にコピー

継承のための適切なメソッドの選択

Object.create と new のどちらを選択するかは、特定の要件によって異なります。 Object.create は、コンストラクターを呼び出さずに継承元となる基本オブジェクトを作成するのに最適です。例:

const Model = {
    // Base object properties and methods...
};

const RestModel = Object.create(Model);
ログイン後にコピー

ただし、継承オブジェクトで基本オブジェクトのコンストラクター関数を呼び出したい場合は、new を使用する必要があります。例:

function Model() {
    // Base object constructor...
}

function RestModel() {
    Model.call(this);
    // Additional properties and methods...
}
ログイン後にコピー

シナリオのソリューション

あなたの場合、Model ベース オブジェクトから RestModel を継承したいとします。 Object.create を使用してこれを実現するには、次の手順を実行します。

RestModel.prototype = Object.create(Model.prototype);
ログイン後にコピー

これにより、Model プロトタイプを継承する新しい RestModel プロトタイプが作成されます。

以上がJavaScript の継承のために new ではなく Object.create を選択するのはどのような場合ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート