JavaScriptプロトタイプチェーン図のまとめと実践

JavaScriptプロトタイプチェーン図のまとめと実践

プロトタイプチェーン

class キーワードは ES6 で導入されましたが、JS はまだプロトタイプベースであり、class は実際には構文上の糖衣です。

たとえば、people クラスがあります。

クラス People {
  コンストラクタ(props) {
    プロパティの名前を変更します。
  }
  走る() {
    コンソールログ('実行')
  }
}

新しい人民階級を通じて、張三や李斯など多くの人々が生み出されます。

let lisi = new People('李四')

しかし、広大な人間の海の中には、並外れた才能を持った人々のグループがいます。彼らはスーパーヒーローと呼ばれています。

クラスHeroはPeopleを拡張します{
   コンストラクタ(props) {
    スーパー(小道具);
    this.power = props.power
   }
   ヘイハ() {
       アラート(this.power)
   }
}

Hero クラスは People を継承しているので、ヒーローはまず run メソッドを持つ個体であり、次に Hero には普通の人にはない超能力 heyHa メソッドがあります。大砲の超能力を持つジンクスというヒーローを次のように定義できます。

Jinx = new Hero({ name: 'jinx', power: 'cannon!' }) とします。

インスタンス Jinx は run メソッドを定義していませんが、プロトタイプ チェーンを使用すると、People プロトタイプにこの run メソッドがあること、つまり、その暗黙的なプロトタイプ __proto__ がコンストラクターのプロトタイプを指していることを確認できます。

ここに画像の説明を挿入

インスタンスがメソッドまたはプロパティにアクセスする場合、インスタンス自体から開始し、プロトタイプ チェーンを遡って検索します。

Jinx.heyHa() // 大砲!
// このメソッドがある場合 Jinx.run = () => console.log('i just fly!')
Jinx.run() // ただ飛ぶだけ!

では、 People.prototype.__proto__どこを指しているのでしょうか? Object.prototype場合、コンソールにコードを入力すると、次のようになります。

ここに画像の説明を挿入

しかし、 Object.prototype__prototype__ null に等しく、宇宙の終わりは無です。 。

ここに画像の説明を挿入

これまでのところ、完全なプロトタイプ チェーン図は次のようになります。

ここに画像の説明を挿入

プロトタイプチェーンに基づいてシンプルなJQueryライブラリを実装することができます

クラス JQuery {
  コンストラクタ(セレクタ、ノードリスト) {
    const res = nodeList || document.querySelectorAll(セレクタ);
    定数長さ = res.length;
    (i = 0; i < 長さ; i++) の場合 {
      this[i] = res[i]
    }
    this.length = 長さ;
    this.selector = セレクター;
  }
  eq(インデックス) {
    新しいJQuery(undefined、[this[index]])を返します。
  }
  それぞれ(fn) {
    for(i = 0; i < this.length; i++) {
      const ele = this[i]
      fn(要素)
    }
    これを返します。
  }
  on(type, fn) {
    this.each(ele => { を返します。
      ele.addEventListener(タイプ、fn、false)
    })
  }
  // 他のDOM APIを拡張する
}
const $$ = (セレクター) => new JQuery(セレクター);
$$('body').eq(0).on('click', () => alert('click'));

コンソールで実行すると、結果は次のようになります。

ここに画像の説明を挿入

要約する

この記事はこれで終わりです。皆さんのお役に立てれば幸いです。また、123WORDPRESS.COM のその他のコンテンツにも注目していただければ幸いです。

以下もご興味があるかもしれません:
  • Javascript プロトタイプとプロトタイプチェーンをご存知ですか?
  • JavaScript のコンストラクター、プロトタイプ、プロトタイプ チェーン、new についてどれくらい知っていますか?
  • JavaScript プロトタイプとプロトタイプチェーンの深い理解
  • Js の継承とプロトタイプチェーンを理解するのに役立つ記事
  • JavaScript プロトタイプチェーンを理解するための 2 つの図
  • JavaScriptプロトタイプとプロトタイプチェーンの詳細な説明

<<:  Web 開発の面接と筆記試験に必須の知識(必読)

>>:  n 個のコンテナ要素による無限スクロールの実装コード

推薦する

tbodyタグの魔法はテーブルコンテンツの表示を高速化します

他の人のウェブページを保存して見たことがあると思いますが、特にdwで開くと、多くのウェブページに&l...

MySQLのスケジュールタスクが正常に実行できない原因の分析と解決

目次序文原因分析と解決策スケジュールされたタスクを迅速に実行する要約する序文データベースのスケジュー...

MySQL データベース トランザクション例のチュートリアル

目次1. トランザクションとは何ですか? 2. トランザクションに関連するステートメントは、挿入、削...

ElementUI の el-dropdown に複数のパラメータを実装する方法

最近、業務上のボタンの増加により、ページレイアウトにボタンが多すぎて、ページが美しくなく、ユーザーエ...

mysql5.7.14 解凍版インストールと設定方法 グラフィックチュートリアル (win10)

Win10はmysql5.7の解凍版をインストールします。参考までに、具体的な内容は次のとおりです...

Nginx リバースプロキシの例の詳細な説明

1. リバースプロキシの例1 1. 効果を達成する(1)ブラウザを開き、www.123.comと入力...

Linux でファイアウォールがオフになっているかどうかを確認する方法

1. サービス方法ファイアウォールのステータスを確認します。 [root@centos6 ~]# サ...

YUM を使用して Linux (CentOS 7) に MySQL 5.7.18 をインストールする方法の詳細なチュートリアル

このプロジェクトでは MySQL を使用する必要があります。これまで Windows では常に確実に...

MySQL オンラインリカバリ UNDO テーブルスペース 実戦記録

1 MySQL5.6 1.1 関連パラメータMySQL 5.6 では、innodb_undo_dir...

webpackでCSSを分割・圧縮し、リンクでインポートする手順

まずコードファイルの構造を見てみましょう。エントリファイル (index1.js) の内容: ...

Dockerコンテナを使用してホストネットワークにアクセスする方法

最近、nginx をリバース プロキシとして使用し、docker で nginx を実行するシステム...

Docker+nacos+seata1.3.0 のインストールと使用設定チュートリアル

これに先立ち、1日かけてやってみました。Seataは使い方が簡単で超シンプルですが、インストールや設...

Vue サーバーに js 構成ファイルをインポートする方法

目次背景成し遂げるvue-cli2.0での設定方法の補足要約する背景プロジェクトにはローカル構成ファ...

Nginx 構成 80 ポート アクセス 8080 とプロジェクト名アドレス メソッド分析

Tomcatはプロジェクトにアクセスします。通常はIP + ポート + プロジェクト名です。 Ngi...

mysql5.7 リモート アクセス設定

mysql5.7 でリモート アクセスを設定することは、ユーザーを作成して権限を付与するだけでアクセ...