ホームページ > ウェブフロントエンド > jsチュートリアル > ES6 では「new」なしでクラス コンストラクターを呼び出すことができますか?

ES6 では「new」なしでクラス コンストラクターを呼び出すことができますか?

Susan Sarandon
リリース: 2024-10-26 01:55:02
オリジナル
387 人が閲覧しました

 Can You Call a Class Constructor Without 'new' in ES6?

ES6 で新しいキーワードを使用せずにクラス コンストラクターを呼び出す

クラス定義が与えられている場合:

class Foo {
  constructor(x) {
    if (!(this instanceof Foo)) return new Foo(x);
    this.x = x;
  }
  hello() {
    return `hello ${this.x}`;
  }
}
ログイン後にコピー

これは不可能ですnew キーワードを使用せずにクラス コンストラクターを直接呼び出します。これは、ES6 のクラスには、クラスの呼び出し時に呼び出されるコンストラクター関数が本質的にあるためです。

新しい結果を持たずにクラスを呼び出すと、エラーが発生します:

Cannot call a class as a function
ログイン後にコピー

このエラー メッセージは、明らかに次のことを示しています。クラス コンストラクターは、クラスの新しいインスタンスを作成するために必要な new 演算子でのみ呼び出すことができます。

この制限を克服するには、次のアプローチを検討してください。

  • 代わりに通常の関数を使用します:
function Foo(x) {
  this.x = x;
  this.hello = function() {
    return `hello ${this.x}`;
  }
}
ログイン後にコピー
  • 常に new でクラスを呼び出します:
(new Foo("world")).hello(); // "hello world"
ログイン後にコピー
  • クラスを関数でラップし、 new で呼び出します:
var FooWrapper = function(...args) { return new Foo(...args) };
FooWrapper("world").hello(); // "hello world"
ログイン後にコピー

以上がES6 では「new」なしでクラス コンストラクターを呼び出すことができますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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