ホームページ >ウェブフロントエンド >フロントエンドQ&A >JavaScript を使用してテンプレート メソッド パターンを実装する方法

JavaScript を使用してテンプレート メソッド パターンを実装する方法

PHPz
PHPzオリジナル
2023-04-25 09:15:45756ブラウズ

テンプレート メソッド パターンは動作設計パターンであり、アルゴリズムのスケルトンを 1 つの操作で定義し、一部のステップをサブクラスに延期することを指します。テンプレート メソッドを使用すると、サブクラスでアルゴリズムの構造を変更せずにアルゴリズムの特定のステップを再定義できます。この記事では、JavaScript を使用してテンプレート メソッド パターンを実装する方法について説明します。

実装メソッド

JavaScript で、テンプレート メソッド パターンを実装するには、次の手順に従う必要があります。

  1. のスケルトンを定義する基本クラスを定義します。操作中のアルゴリズム。操作には関数またはクラス メソッドを使用できます。
  2. アルゴリズムのいくつかのステップを基本クラスに実装します。これらのステップは、抽象メソッドまたは具体的な実装にすることができます。これらの手順を実装するときは、これらの手順がサブクラスによってオーバーライドされることを前提とする必要があります。
  3. サブクラスを定義し、基本クラスに抽象メソッドを実装するか、基本クラスの特定の実装を変更します。
  4. インスタンスを作成し、基本クラスでオペレーションを呼び出します。これにより、基本クラスに実装されたアルゴリズム ステップとサブクラスでオーバーライドされたステップが呼び出されます。

これは、JavaScript でテンプレート メソッド パターンを実装する方法を示す例です。 2 つの数値の合計の計算を定義する基本クラス Operation を作成するとします。この操作は 2 つのステップで構成されます。最初に 2 つの数値が加算され、次に結果がフォーマットされます。テンプレート メソッド パターンを使用してこの操作を実装し、結果のフォーマット方法をサブクラスに決定させます。

class Operation {
  constructor(a, b) {
    this.a = a;
    this.b = b;
  }

  getResult() {
    const sum = this.sum();
    return this.format(sum);
  }

  sum() {
    return this.a + this.b;
  }

  format(result) {
    // 由子类决定如何格式化结果
    throw new Error('该方法必须由子类实现');
  }
}

上記のコードでは、2 つの数値 ab を含む Operation クラスを定義し、 getResult## を実装します。 # 方法。このメソッドは、sum メソッドと format メソッドを呼び出します。これらは、2 つの数値の合計を計算し、結果をそれぞれ特定の形式にフォーマットします。 format メソッドは抽象メソッドであるため、このメソッドをサブクラスに実装する必要があります。

これで、計算結果を 10 進数としてフォーマットするサブクラス

DecimalFormatOperation を作成できます。

class DecimalFormatOperation extends Operation {
  format(result) {
    return result.toFixed(2);
  }
}
上記のコードでは、

Operation クラスを継承し、format メソッドを実装します。このメソッドは計算結果を小数点第2位に四捨五入して返します。

これで、インスタンスを作成し、

getResult メソッドを呼び出すことができます。

const op = new DecimalFormatOperation(2.2, 3.3);
const result = op.getResult();
console.log(result); // '5.50'
上記のコードでは、

DecimalFormatOperation op と入力し、2 つの数値 2.23.3 を渡します。次に、getResult メソッドを呼び出し、結果を result 変数に保存します。最後に、結果を '5.50' としてコンソールに出力します。

結論

テンプレート メソッド パターンは、コードをより適切に整理し、アルゴリズムのスケルトンを定義する柔軟な方法を提供するために JavaScript で使用できる非常に便利な設計パターンです。このパターンの主な利点は、コードの理解と保守が容易になると同時に、コードの再利用も容易になることです。複雑なアルゴリズムを頻繁に作成する場合、またはいくつかの一般的な操作を実装する必要がある場合は、テンプレート メソッド パターンが必要な設計パターンになる可能性があります。

以上がJavaScript を使用してテンプレート メソッド パターンを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。