+5

JavaScriptでファクトリーデザインパターンを理解する

ファクトリーパターンは、スーパークラスでオブジェクトを作成する人気のあるデザインパターンであり、サブクラスが作成されるオブジェクトのタイプを変更できるようにします。これは、オブジェクトを作成するための一貫したインターフェースを提供しつつ、実際に作成されるオブジェクトのタイプを柔軟にする必要がある場合に便利です。

この記事では、ファクトリーパターンが何であるかと、JavaScriptで関数型プログラミングを使用してどのように実装できるかを見ていきます。また、ファクトリーパターンをコードで使用するメリットとデメリットについても議論します。

ファクトリーパターンとは何ですか?

ファクトリーパターンは、スーパークラスでオブジェクトを作成する方法であり、サブクラスが作成されるオブジェクトの種類を変更することができるようにするものです。 これは、スーパークラスに特定のタイプのオブジェクトを作成するための引数を受け取るファクトリーメソッドを作成することで実現されます。

例えば、フルタイム、パートタイム、テンポラリ、および契約社員など、異なる種類のエンプロイオブジェクトを作成する必要があるシステムを考えてみます。 各種類のエンプロイオブジェクト用に別々のクラスを作成する代わりに、タイプ引数を受け取るファクトリーメソッドを持つ単一のEmployeeクラスを使用して、ファクトリーパターンを使用して適切なタイプのエンプロイオブジェクトを作成できます。

JavaScriptでファクトリーパターンを実装するには、オブジェクトを返す関数を使用することができます。そのファクトリーメソッドは、それに渡される引数に基づいて、異なるタイプのオブジェクトを作成するために使用できます。

ここに、JavaScriptでファクトリーパターンがどのように実装されるかの例があります。

function Factory() {
  this.createEmployee = function(type) {
    let employee;

    if (type === "fulltime") {
      employee = new FullTime();
    } else if (type === "parttime") {
      employee = new PartTime();
    } else if (type === "temporary") {
      employee = new Temporary();
    } else if (type === "contractor") {
      employee = new Contractor();
    }

    employee.type = type;

    employee.say = function() {
      console.log(`I am a ${this.type}, and I get ${this.hourly}/hour`);
    }

    return employee;
  }
}

const FullTime = function() {
  this.hourly = "$12";
};

const PartTime = function() {
  this.hourly = "$11";
};

const Temporary = function() {
  this.hourly = "$10";
};

const Contractor = function() {
  this.hourly = "$15";
};

const factory = new Factory();

const fullTimeEmployee = factory.createEmployee("fulltime");
fullTimeEmployee.say(); // "I am a fulltime, and I get $12/hour"

const partTimeEmployee = factory.createEmployee("parttime");
partTimeEmployee.say(); // "I am a parttime, and I get $11/hour"

この例では、ファクトリー関数には、タイプ引数を取り、そのタイプに基づいて従業員オブジェクトを作成するcreateEmployeeメソッドがあります。createEmployeeメソッドは、どのタイプの従業員を作成するかを判断するために複数のif文を使用し、その後、従業員オブジェクトのhourlyプロパティをタイプに基づいて設定します。次に、従業員オブジェクトのsayメソッドを使用して、コンソールにメッセージをログすることができます。

FullTimePartTimeTemporary、およびContractor関数は、従業員オブジェクトの特定のプロパティを定義するサブクラスです。

ファクトリーパターンの利点

ファクトリーパターンをコードに使用することには、いくつかの利点があります:

  • 柔軟性: ファクトリーパターンは、作成されるオブジェクトの種類についての柔軟性を提供し、必要に応じてオブジェクトの種類を追加または削除しやすくなります。

  • コードの再利用: ファクトリーパターンは、同じファクトリーメソッドを使用して異なる種類のオブジェクトを作成することで、コードの再利用を可能にします。

  • 使いやすい: ファクトリーパターンは、オブジェクトを作成するための一貫したインタフェースを提供し、システムの他の部分が使いやすくなります。

ファクトリーパターンの欠点

ファクトリーパターンにはいくつかの利点がありますが、欠点もあるため注意する必要があります。

  • 複雑さ: ファクトリーパターンは、複数のサブクラスを作成し、ファクトリーメソッドを作成する必要があるため、コードをより複雑にする可能性があります。

  • 強い結合: ファクトリーパターンは、オブジェクトとファクトリーメソッドの間に強い結合を生成する可能性があり、オブジェクトの振る舞いを変更または修正することがより困難になることがあります。

  • テストの困難さ: ファクトリーパターンは、テストのためにオブジェクトをモックやスタブすることが困難であるため、コードのテストをより困難にすることがあります。

ファクトリーパターンを使用するとき

異なる種類のオブジェクトを作成する必要があるときであり、それらを作成するための一貫したインタフェースを提供したいときに、ファクトリーパターンが最も役立ちます。 これは、さまざまなオブジェクトを作成する必要があるシステムがあり、オブジェクトの特定の実装が時間の経過とともに変更される場合に起こるかもしれません。

しかし、ファクトリーパターンは必要に応じてのみ使用することが重要であることを忘れないでください。 ファクトリーパターンの過剰使用は、複雑で保守やテストが困難なコードにつながる可能性があります。

結論

ファクトリーパターンは、スーパークラスで異なる種類のオブジェクトを作成するための有用なツールであり、サブクラスが作成される特定の種類のオブジェクトを変更できるようにします。 これは柔軟性とコードの再利用を提供しますが、また複雑さを増加させ、タイトカップリングを生じることもあります。 ファクトリーパターンを必要に応じてのみ使用することが重要であり、その潜在的な欠点を認識することが重要です。

この記事が、ファクトリーパターンを理解するのに役立ち、またJavaScriptで関数型プログラミングを使用してそれを実装する方法を理解するのに役立つと思います。 もし質問があるか、またはソフトウェア開発におけるデザインパターンについてもっと知りたいと思う場合は、お気軽に質問してください。

Mình hy vọng bạn thích bài viết này và học thêm được điều gì đó mới.

Donate mình một ly cafe hoặc 1 cây bút bi để mình có thêm động lực cho ra nhiều bài viết hay và chất lượng hơn trong tương lai nhé. À mà nếu bạn có bất kỳ câu hỏi nào thì đừng ngại comment hoặc liên hệ mình qua: Zalo - 0374226770 hoặc Facebook. Mình xin cảm ơn.

Momo: NGUYỄN ANH TUẤN - 0374226770

TPBank: NGUYỄN ANH TUẤN - 0374226770 (hoặc 01681423001)

image.png


All rights reserved

Viblo
Hãy đăng ký một tài khoản Viblo để nhận được nhiều bài viết thú vị hơn.
Đăng kí