ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript でのメソッド定義にオブジェクト リテラル表記ではなくオブジェクト プロトタイプを選択する理由

JavaScript でのメソッド定義にオブジェクト リテラル表記ではなくオブジェクト プロトタイプを選択する理由

DDD
リリース: 2024-11-12 08:36:01
オリジナル
786 人が閲覧しました

Why Choose Object Prototype Over Object Literal Notation for Method Definition in JavaScript?

new Object() とオブジェクト リテラル表記の違い

JavaScript でオブジェクトを作成するには、次の 2 つの方法があります。コンストラクターを使用します。 new Object() 構文またはオブジェクト リテラル表記に基づいています。どちらのメソッドも同じ結果が得られるように見えますが、オブジェクトにメソッドを追加する場合には大きな違いがあります。

オブジェクト リテラル表記

オブジェクト リテラル表記を使用する場合、メソッドは次のようになります。個々のオブジェクト内で定義されているため、多数のオブジェクトやメソッドが関係する場合は潜在的にメモリを浪費する可能性があります。

function Obj(prop) {
    return {
        p: prop,
        sayHello: function() {
            alert(this.p);
        },
    };
}

const foo = new Obj("hello");
ログイン後にコピー

コンストラクターベースの構文

対照的に、新しい Object() 構文では、メソッドがオブジェクト プロトタイプで定義され、すべてのオブジェクト インスタンス間で共有されるため、メモリ使用量が最適化されます。

function Obj(prop) {
    this.p = prop;
}

Obj.prototype.sayHello = function() {
    alert(this.p);
};

const foo = new Obj("hello");
ログイン後にコピー

オブジェクト プロトタイプを使用する利点

コンストラクターベースの構文とオブジェクト プロトタイプを利用することで、次の利点が得られます:

  • メモリ消費量の削減: 共有メソッドにより、各オブジェクトに重複したメソッド定義を保存する必要がなくなります。 .
  • コードのメンテナンスが簡単: プロトタイプ内の集中メソッドにより、すべてのインスタンスを簡単に変更できます。

以上がJavaScript でのメソッド定義にオブジェクト リテラル表記ではなくオブジェクト プロトタイプを選択する理由の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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