この記事では、以下の内容を取り上げます。
テレポートの目的まず、テレポート機能をいつ、どのように使用するのかについて説明します。 大規模な 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 クエリ文字列を指定します。
#portal-target でコードを渡したので、Vue プログラムは index.html に含めた #portal-target div を見つけ、ポータル内のすべてのコードを渡してその div でレンダリングします。 結果は次のとおりです。 要素を検査して DOM を見ると、何が起こっているのかがかなり明確にわかります。 VuePortals コンポーネントのすべてのロジックを使用できますが、どのテンプレート コードを別の場所にレンダリングするかをプロジェクトに指示する必要があります。 以上がVue3のTeleportの詳しい説明です。Vue3のTeleportについてさらに詳しく知りたい方は、123WORDPRESS.COMの関連記事もぜひご覧ください! 以下もご興味があるかもしれません:
|
>>: docker run によって起動されたコンテナがハングしてデータが失われた場合の対処方法
目次序文1. GMT GMTとはGMTの歴史2. UTC UTCとはUTC は次の 2 つの部分で構...
1. Apacheサーバーのインストールと設定yum インストール httpd -y systemc...
Centos や Ubuntu など、Docker が pull する Base イメージは最もシン...
バントリストコンポーネントをスクロールするときに、スクロールバーの位置が保持されます。これは、kee...
ユーザーのホーム ディレクトリがどんどん大きくなってきたら、ホーム ディレクトリを新しいパーティショ...
序文すでに Docker をインストールしており、Docker について簡単に理解しています。ここで...
MySQL をインストールするための前提条件: CentOS 7 64 ビットをインストールし、Ce...
[必須] ユーザーインターフェースPhotoShop/花火デザインアーティストと協力して、スケッチを...
オフィスでは、Linux 開発環境として Ubuntu システムが必要です。現在、Ubuntu 16...
問題を見つける今日、仕事中に、ローカル データベースから仮想マシン CentOS 6.6 上のデータ...
複合インデックス (結合インデックスとも呼ばれます) は、複数の列に対して作成されるインデックスです...
目次序文InnoDB ストレージ アーキテクチャInnodb テーブルスペースインドストレージディス...
html: 実際には、テーブルタグに従っていくつかの実線の円 div を正六角形に配置し、div コ...
この記事では、例を使用して、MySQL ストアド プロシージャで複数の値を返す方法について説明します...
ブランクのブログ: http://www.planabc.net/ innerHTML プロパティは...