コンストラクタnew を導入する前に、コンストラクターとは何かを知っておく必要があります。 コンストラクタと通常の関数の書き方には違いはありません。関数が new Fun() を通じて呼び出される場合、それはコンストラクタと呼ばれ、コンストラクタの最初の文字は通常大文字になります。 関数 User(名前) { this.name = 名前; } u = new User('leo'); とします。 ここで、User はコンストラクタです。もちろん、User() を直接呼び出すこともできますが、これではインスタンスは作成されません。非厳密モードでは、name 属性がウィンドウにハングします。 新しいオペレーターでは、インスタンスを作成するために new 演算子は具体的に何を行うのでしょうか? new 演算子は、ユーザー定義のオブジェクト タイプのインスタンス、またはコンストラクターを持つ組み込みオブジェクトのインスタンスを作成します。新しいキーワードは次の操作を実行します。 1. 空の単純な JavaScript オブジェクト (つまり **{}**) を作成します。 2. オブジェクトを別のオブジェクトにリンクします(つまり、オブジェクトのコンストラクターを設定します)。 3. 手順 1 で新しく作成したオブジェクトを **this** のコンテキストとして使用します。 4. 関数がオブジェクトを返さない場合は、**this** を返します。 上記は新しいオペレータ - MDN から引用したものです おそらく手順 2 と 4 がよく理解されていないと思うので、ここでもう一度要約します。 1. 空のオブジェクトを作成する u = {} 2. プロトタイプをバインド、u.__proto__ = User.prototype 3. User() 関数を呼び出し、空のオブジェクト u を this として渡します。つまり、User.call(u) です。 4. User() 関数が実行後にオブジェクト型を返す場合はこの変数を返し、そうでない場合はこれを返します。注: コンストラクタが基本型の値を返す場合は影響を受けず、これを返します。 自分で新しいものを実装するnew 演算子の原理を理解した上で、FakeNew 関数を自分で実装してみましょう。 関数FakeNew() { obj = {} とします。 // 配列のような引数を配列に変換し、コンストラクターである最初のパラメーターをシフトアウトします。letconstructor = [].shift.apply(arguments); // プロトタイプをバインドします obj.__proto__ =constructor.prototype; // コンストラクターを呼び出して、obj を次のように渡します。let res = Constructor.apply(obj, arguments); // 戻り値 return typeof res === 'object' ? res : obj; } 関数 User(名前) { this.name = 名前; } User.prototype.getName = 関数() { this.name を返します。 } u = FakeNew(User, 'leo') とします。 コンソールにログ出力します。 コンソールにログ出力します。 対応するキーステップのコメントがコードに添付されているので、新しい操作を実装しました。今後新しいものを見ると、より明確な感覚が得られると思います。 以上がJavaScriptのnew演算子を自分で実装する方法の詳細です。JavaScriptのnew演算子の詳細については、123WORDPRESS.COMの他の関連記事に注目してください。 以下もご興味があるかもしれません:
|
<<: keepalived+nginx の高可用性を実装する方法の例
>>: MySQL 5.7.21 のインストールとパスワード設定のチュートリアル
1. mysqlにログインします。 mysql -u ルート -h 127.0.0.1 -p 2. ...
ここで 123WORDPRESS.COM はこれらのテンプレートの最初の部分を紹介します。各テンプレ...
この記事では、WeChatアプレットの計算機機能を実装するための具体的なコードを参考までに紹介します...
効果は以下のとおりです。 例1 例2:例1[結婚式の計画]を例にとるHTML: <div cl...
コードをコピーコードは次のとおりです。 <input type="text"...
——「MySQL in Simple Terms (第 2 版)」からのメモ数値型整数型バイト最小最...
少し前にTikTokで揺れる連打が流行っていたので真似してみることにしました。さっそく効果をみてみま...
Vueボタンコンポーネントのカスタムカプセル化コードは参考用です。具体的な内容は次のとおりです。ボタ...
MyISAM と InnoDB は、MySQL で最も一般的なストレージ エンジンです。前回の記事で...
前回の記事「1行のCSSコードの魅力」では、たった1行のCSSコードで生成できる美しい(奇妙な感じと...
各ブラウザの select タグのプロパティと各ブラウザのサポートが多少異なるため、各ブラウザでの選...
順序なしリストでは、順序なしリストのシンボルは各リストの前に表示されるドットです。順序付きリスト o...
この記事の例では、ジグソーパズルゲームを実装するためのJavaScriptの具体的なコードを参考まで...
1. 需要ベースには 300 台の新しいサーバーがあり、CentOS7.6 オペレーティング システ...
Docker の使用に関するヒント1. 停止したDockerコンテナをすべてクリーンアップする停止し...