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 によって起動されたコンテナがハングしてデータが失われた場合の対処方法

推薦する

フロントエンドJavaScriptの動作原理

目次1. JavaScript エンジンとは何ですか? 2. V8エンジン3. ランタイム環境4. ...

VMware ESXi CLI の一般的なコマンドを調べる

目次【共通コマンド】 [一般的な esxi コマンドの概要] [esxcli コマンドの調査] ES...

MySQLユーザー管理操作例の分析

この記事では、MySQL ユーザー管理操作について説明します。ご参考までに、詳細は以下の通りです。こ...

JS の new 関数の詳細な説明

目次1. 例2. 兵士100人を作成する3. 質問4. 改善点5. エレガント? 6. JSの父から...

Ajax の JavaScript ソリューションにおける parsererror エラー ケースの詳細な説明

ajax の parsererror エラー (バックグラウンドからフロントエンドに送信される js...

Apache ストレステストツールのインストールと使用

1. ダウンロードApacheの公式サイトhttp://httpd.apache.org/にアクセス...

Linux CentOS インストール JDK および Tomcat チュートリアル

まずJDKをダウンロードします。ここではjdk-8u181-linux-x64.tar.gzを使用し...

http-proxy-middlewareを使用してNodeでプロキシクロスドメインを実装する方法と手順

目次1. プロキシモジュールをインストールする2. プロキシを設定する1. プロキシモジュールをイン...

Svelte の Defer Transition を Vue で実装する方法

最近、Rich Harris の <Rethinking Reactivity> ビデオ...

Docker に Zookeeper を素早くインストールする方法の詳細なチュートリアル

Docker で Zookeeper を素早くインストール会社を変わってから長らくZookeeper...

Centos7にnginxをインストールする方法

必要な環境をインストールする1. gccのインストールnginx をインストールするには、公式サイト...

CSS の複数行テキストがオーバーフローする場合の省略記号の例

複数行のテキストがオーバーフローすると省略記号が表示されますこの記事では 2 つの方法を推奨します。...

Vueはユーザー名が使用可能かどうかの検証を実装します

この記事では、ユーザー名が使用可能かどうかを確認するためのVueの具体的なコードを例として紹介します...

CSS3 タイムラインアニメーション

成果を達成する html <h2>CSS3 タイムライン</h2> <...

Node.js のフロントエンドとバックエンドのインタラクションによるユーザーログインの実装の実践

目次1. プロジェクト要件次にコーディングを始める1. フロントエンドページを作成する(CSSスタイ...