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 個のコンテナ要素による無限スクロールの実装コード

推薦する

ウェブデザインにおけるキーワード設計手法の紹介

多くの場合、ホームページを作成するときに、Web ページ ヘッダー属性の設定を無視します。 Web ...

JS 面接の質問: forEach はループから抜け出すことができますか?

この質問をされたとき、私は無知で頭が真っ白になりました。もちろん、正しく答えられませんでした。私はず...

スタイルをより標準化するための CSS の書き方に関する 5 つのヒント

1. CSSをアルファベット順に並べるアルファベット順ではありません:コードをコピーコードは次のとお...

MySQL ジョイントインデックス(複合インデックス)の実装

共同インデックスこの記事におけるジョイントインデックスの定義は次のとおりです (MySQL): AL...

Mysqlマスタースレーブ同期の実装原理

1. MySQL マスター/スレーブ同期とは何ですか?マスター データベースのデータが変更されると、...

CSS のインライン スタイルに変換するソリューション (css-inline)

シーンについて話すメールを送信サードパーティのウェブサイトにHTMLを埋め込む他の編集者の記事をコピ...

ウィンドウ環境設定Mysql 5.7.21 windowx64.zip無料インストール版チュートリアル詳細説明

1. 公式サイトのmysqlダウンロードページからmysql-5.7.21-windowx64.zi...

VUEをベースにしたシンプルな学生情報管理システムの実装

目次1. 主な機能2. 実装のアイデア3. コードの実装4. エフェクト表示V. 結論1. 主な機能...

Dockerはポートマッピングを設定しますが、ソリューションにアクセスできません

#docker ps チェック、すべてのポートがマップされています コンテナID イメージ コマンド...

HTML から PDF への変換事例の概要 (複数の画像を推奨)

仕事の都合上、最近 HTML を PDF に変換する機能について調べることに時間を費やしました。 H...

Vue フロントエンド開発における keepAlive の使用方法の詳細な説明

目次序文keep-avlive フック関数keep-avliveはどのコンポーネントをキャッシュする...

Vue3における非親子コンポーネント通信の詳細な説明

目次最初の方法アプリ.vueホーム.vueホームコンテンツ.vueデータの応答性レスポンシブプロパテ...

MySQL 8.0.22.0 のダウンロード、インストール、設定方法のグラフィックチュートリアル

MySQL 8.0.22のダウンロード、インストール、設定方法、参考までに具体的な内容は次のとおりで...

5 分で vue-cli3 を使用してプロジェクトを作成する方法を説明します (初心者向けガイド)

目次1. Vue環境を構築する2. Vue スキャフォールディングツール3. プロジェクトを作成する...

MySQL マスタースレーブ構成の学習ノート

● 新しいプロジェクトのセキュリティを確保するためにクラウド データを購入する予定でした。 Alib...