Vue3 での Teleport の使用に関する詳細な説明

Vue3 での Teleport の使用に関する詳細な説明

この記事では、以下の内容を取り上げます。

  • テレポートの目的
  • テレポートの例
  • 興味深いコードの相互作用

テレポートの目的

まず、テレポート機能をいつ、どのように使用するのかについて説明します。

大規模な Vue プロジェクトを開発する場合は、コードを再利用可能なロジックに整理する必要があります。ただし、モーダル、通知、ツールチップなどの特定の種類のコンポーネントを扱う場合、テンプレート HTML のロジックは、レンダリングされる要素が必要なファイルと同じファイルにない可能性があります。

実際、ほとんどの場合、Vue の完全に独立した DOM を使用するよりも、これらの要素を処理する方がはるかに簡単です。ネストされたコンポーネントの位置、z-index、スタイルなどは、すべての親のスコープに対処する必要があるため、複雑になることがあります。

ここでテレポートが役立ちます。ロジックが配置されているコンポーネントにテンプレート コードを記述すると、コンポーネントのデータやプロパティを使用できるようになります。

Teleport がなければ、子コンポーネントから DOM ツリーにロジックを渡すためのイベント伝播についても考慮する必要があります。

テレポートの仕組み

通知ポップアップをトリガーする子コンポーネントがあるとします。先ほど説明したように、通知が Vue のルート #app 要素ではなく、完全に別の DOM ツリーでレンダリングされる方がはるかに簡単になります。

まず、index.html を編集し、</body> の前に <div> を追加します。

//インデックス.html
<本文>
   <div id="アプリ"></div>
   <div id='ポータルターゲット'></div>
</本文>

次に、レンダリング通知をトリガーするコンポーネントを作成します。

//Vueポータル.vue
<テンプレート>
  <div class='ポータル'>
    <button @click='showNotification'> 通知をトリガーします! </button>
    <テレポート先='#portal-target'>
      <div クラス = '通知'>
        これは、この子コンポーネントの外部でレンダリングされます。
      </div>
    </テレポート>
  </div>
</テンプレート>

<スクリプト>
'vue' から { ref } をインポートします
エクスポートデフォルト{
  設定 () {
    定数isOpen = ref(false)

    var ポップアップを閉じる

    const showNotification = () => {
      isOpen.値 = true

      タイムアウトをクリア(ポップアップを閉じる)

      closePopup = setTimeout(() => {
        isOpen.値 = false
      }, 2000)
    }

    戻る {
      開いている、
      通知を表示
    }
  }
}
</スクリプト>

<スタイルスコープ>
  。通知 {
    フォントファミリー: myriad-pro、sans-serif;
    位置: 固定;
    下: 20px;
    左: 20px;
    幅: 300ピクセル;
    パディング: 30px;
    背景色: #fff;
  }
</スタイル>

このコード スニペットでは、ボタンが押されると、通知が 2 秒間表示されます。しかし、私たちの主な目標は、Teleport を使用して通知を取得し、VUE プログラム外でレンダリングすることです。

ご覧のとおり、Teleportには必須の属性が1つあります。

to 属性には、次のような有効な DOM クエリ文字列を指定します。

  • 要素のID
  • 要素のクラス
  • データセレクター
  • 応答クエリ文字列

#portal-target でコードを渡したので、Vue プログラムは index.html に含めた #portal-target div を見つけ、ポータル内のすべてのコードを渡してその div でレンダリングします。

結果は次のとおりです。

要素を検査して DOM を見ると、何が起こっているのかがかなり明確にわかります。

VuePortals コンポーネントのすべてのロジックを使用できますが、どのテンプレート コードを別の場所にレンダリングするかをプロジェクトに指示する必要があります。

以上がVue3のTeleportの詳しい説明です。Vue3のTeleportについてさらに詳しく知りたい方は、123WORDPRESS.COMの関連記事もぜひご覧ください!

以下もご興味があるかもしれません:
  • Vue3の組み込みコンポーネントであるTeleportの使い方を詳しく説明します
  • Vue3 Teleportの実践と原理の詳細な説明
  • vue3のテレポート瞬間移動機能の使い方を詳しく解説
  • vue2 で vue3 のテレポートを実装する方法

<<:  Centos7.5でのIPアドレス設定の実装

>>:  docker run によって起動されたコンテナがハングしてデータが失われた場合の対処方法

推薦する

JSはGMTとUTCのタイムゾーンを完全に理解しています

目次序文1. GMT GMTとはGMTの歴史2. UTC UTCとはUTC は次の 2 つの部分で構...

Apache の一般的な仮想ホスト設定方法の分析

1. Apacheサーバーのインストールと設定yum インストール httpd -y systemc...

Dockerで構築されたコンテナにpingツールをインストールする

Centos や Ubuntu など、Docker が pull する Base イメージは最もシン...

バントリストコンポーネントをスクロールしても、スクロールバーの位置は保持されます。

バントリストコンポーネントをスクロールするときに、スクロールバーの位置が保持されます。これは、kee...

Ubuntu でホームディレクトリを新しいパーティションに移行する詳細なチュートリアル

ユーザーのホーム ディレクトリがどんどん大きくなってきたら、ホーム ディレクトリを新しいパーティショ...

DockerでMySQLコンテナを作成する簡単な手順

序文すでに Docker をインストールしており、Docker について簡単に理解しています。ここで...

CentOS7 64ビットインストールmysqlグラフィックチュートリアル

MySQL をインストールするための前提条件: CentOS 7 64 ビットをインストールし、Ce...

Webフロントエンドインターフェースの設計に必須のスキル

[必須] ユーザーインターフェースPhotoShop/花火デザインアーティストと協力して、スケッチを...

開発環境にUbuntu 16をインストール後の初期設定

オフィスでは、Linux 開発環境として Ubuntu システムが必要です。現在、Ubuntu 16...

MySQL の起動時に InnoDB エンジンが無効になる問題の解決方法

問題を見つける今日、仕事中に、ローカル データベースから仮想マシン CentOS 6.6 上のデータ...

MySQL複合インデックスの詳細な研究

複合インデックス (結合インデックスとも呼ばれます) は、複数の列に対して作成されるインデックスです...

MySQLがデータの削除を推奨しない理由

目次序文InnoDB ストレージ アーキテクチャInnodb テーブルスペースインドストレージディス...

CSS3 とテーブルタグを使用して円軌道アニメーションを実装するためのサンプルコード

html: 実際には、テーブルタグに従っていくつかの実線の円 div を正六角形に配置し、div コ...

複数の値を返す MySQL ストアド プロシージャ メソッドの例

この記事では、例を使用して、MySQL ストアド プロシージャで複数の値を返す方法について説明します...

innerHTML アプリケーション

ブランクのブログ: http://www.planabc.net/ innerHTML プロパティは...