この記事では、以下の内容を取り上げます。
テレポートの目的まず、テレポート機能をいつ、どのように使用するのかについて説明します。 大規模な 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 によって起動されたコンテナがハングしてデータが失われた場合の対処方法
MySQL 開発チームは、2019 年 10 月 14 日に MySQL 8.0.18 GA バージ...
次のように: -m, --memory メモリ制限。形式は数値と単位です。単位は b、k、m、g の...
1. Linuxグループの基本紹介Linux では、すべてのユーザーはグループに所属する必要があり、...
CS: ...コードをコピーコードは次のとおりです。 html,body{ margin:0px; ...
RGBAは色の値と透明度を設定できるCSSカラーです以下は、rgba() を使用して白色を 50% ...
1. レンダリング 2. ソースコードhtml < 本文 > < div クラス ...
CSS は、スタイル、レイアウト、プレゼンテーションの領域です。色彩、サイズ、アニメーションが溢れて...
目次質問解決質問この問題には多くの理由があるようです。私の問題は、パラメータ付きのURLを更新できな...
1. 温かくて優しい関連アドレス: http://www.web-designers.cn/post...
テスト サーバーにログインするたびに、必ず ssh ログインのパスワードを入力する必要があります。ロ...
導入:多くの場合、さまざまな選択ステートメントを使用して必要なデータを照会した後、多くの人は作業が正...
【著者】 Liu Bo: Ctrip テクニカル サポート センターのシニア データベース マネージ...
2020 年 4 月 23 日、本日、Windows 上の Ubuntu 20.04 では、Ubun...
目次01 コンテナの一貫性02 レイヤーの概念03 レイヤードデザインの利点今日はコンテナ レイヤー...
今日、Alibaba Cloudからディスク警告通知を受け取りました。確認したところ、100Gのスペ...