導入
Vue 2 に慣れている方は、すべてのコンポーネントのテンプレートに 1 つのルート要素が必要だったことを覚えているかもしれません。 Vue 3 では、フラグメントがあるため、これは必要なくなりました。これは、コンポーネントがラッパーを必要とせずに複数のルート要素を持つことができることを意味します。
<!-- Vue 2 --> <template> <div> <!-- wrapper ? --> <h1 id="My-Blog-Post">My Blog Post</h1> <articlecomponent>{{ content }}</articlecomponent> </div> </template> <!-- Vue 3 --> <template> <h1 id="My-Blog-Post">My Blog Post</h1> <articlecomponent>{{ content }}</articlecomponent> </template>
これは React の Fragment に非常に似ています。ただし、Vue はバックグラウンドでフラグメントを処理します。実際、Vue 3 では、 を考えることができます。フラグメントとしてタグを付けます。
ref() の問題
Vue 2 では、子コンポーネントに ref を簡単に設定でき、ラッパー要素 と コンポーネント インスタンス の両方を参照します。
しかし、Vue 3 では、ラッパー要素がない場合、ref は何を参照するのでしょうか? ?
子コンポーネントが オプション API を使用する場合、または を使用しない場合、ref は子コンポーネントの this をポイントし、親に完全なアクセス権を与えます。そのプロパティとメソッド。
を使用するとどうなるでしょうか?
を使用するコンポーネントは、デフォルトでは プライベートです。プロパティを公開するには、defineExpose マクロを使用する必要があります。
子要素へのアクセス
- ラッパー (単一ルート) 要素がある場合は次のようになります。
<!-- Child --> <template> <div> <ul> <li>And when you have more than one root: </li> </ul> <pre class="brush:php;toolbar:false"><!-- Child --> <template> <h1 id="My-Blog-Post">My Blog Post</h1> <!-- Root 1 --> <articlecomponent>{{ content }}</articlecomponent> <!-- Root 2 --> </template> <!-- Parent --> <script setup lang="ts"> const childRef = ref() onMounted(()=>{ console.log(childRef.value.$el); // #text }) </script> <template> <child ref="childRef"></child> </template>
ちょっと待って、何が起こったの?
Fragment(複数ノード) を使用すると、Vue は子コンポーネントのルート ノードをラップするテキスト ノードを作成します。
Vue 3 でフラグメントを使用する場合、Vue はコンポーネントの先頭に空のテキスト ノードをマーカーとして挿入します。そのため、$el は #text ノードを返します。
#text は、Vue が内部で使用する参照ポイントのようなものです。
また、コンポーネント インスタンスに引き続きアクセスできることにも言及しておきます (子で
解決
1) このように単一ルートを使用します
2) テンプレート参照を使用するdefineExpose
テンプレート参照の使用
<!-- Child --> <script setup lang="ts"> import { ref } from 'vue'; const h1Ref = ref() const articleRef = ref() defineExpose({ h1Ref, articleRef }) </script> <template> <h1 id="My-Blog-Post">My Blog Post</h1> <articlecomponent ref="articleRef">{{ content }}</articlecomponent> </template> <!-- Parent --> <script setup lang="ts"> const childRef = ref() onMounted(()=>{ console.log(childRef.value); // {h1Ref: RefImpl, articleRef: RefImpl} }) </script> <template> <child ref="childRef"></child> </template>
これで、refs と、defineExpose を使用して公開したすべてのものにアクセスできるようになりました。
以上が本番スタックの構築: Docker、Meilisearch、NGINX、NestJSの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

JavaScriptコアデータ型は、ブラウザとnode.jsで一貫していますが、余分なタイプとは異なる方法で処理されます。 1)グローバルオブジェクトはブラウザのウィンドウであり、node.jsのグローバルです2)バイナリデータの処理に使用されるNode.jsの一意のバッファオブジェクト。 3)パフォーマンスと時間の処理にも違いがあり、環境に従ってコードを調整する必要があります。

javascriptusestwotypesofcomments:シングルライン(//)およびマルチライン(//)

PythonとJavaScriptの主な違いは、タイプシステムとアプリケーションシナリオです。 1。Pythonは、科学的コンピューティングとデータ分析に適した動的タイプを使用します。 2。JavaScriptは弱いタイプを採用し、フロントエンドとフルスタックの開発で広く使用されています。この2つは、非同期プログラミングとパフォーマンスの最適化に独自の利点があり、選択する際にプロジェクトの要件に従って決定する必要があります。

PythonまたはJavaScriptを選択するかどうかは、プロジェクトの種類によって異なります。1)データサイエンスおよび自動化タスクのPythonを選択します。 2)フロントエンドとフルスタック開発のためにJavaScriptを選択します。 Pythonは、データ処理と自動化における強力なライブラリに好まれていますが、JavaScriptはWebインタラクションとフルスタック開発の利点に不可欠です。

PythonとJavaScriptにはそれぞれ独自の利点があり、選択はプロジェクトのニーズと個人的な好みに依存します。 1. Pythonは、データサイエンスやバックエンド開発に適した簡潔な構文を備えた学習が簡単ですが、実行速度が遅くなっています。 2。JavaScriptはフロントエンド開発のいたるところにあり、強力な非同期プログラミング機能を備えています。 node.jsはフルスタックの開発に適していますが、構文は複雑でエラーが発生しやすい場合があります。

javascriptisnotbuiltoncorc;それは、解釈されていることを解釈しました。

JavaScriptは、フロントエンドおよびバックエンド開発に使用できます。フロントエンドは、DOM操作を介してユーザーエクスペリエンスを強化し、バックエンドはnode.jsを介してサーバータスクを処理することを処理します。 1.フロントエンドの例:Webページテキストのコンテンツを変更します。 2。バックエンドの例:node.jsサーバーを作成します。

PythonまたはJavaScriptの選択は、キャリア開発、学習曲線、エコシステムに基づいている必要があります。1)キャリア開発:Pythonはデータサイエンスとバックエンド開発に適していますが、JavaScriptはフロントエンドおよびフルスタック開発に適しています。 2)学習曲線:Python構文は簡潔で初心者に適しています。 JavaScriptの構文は柔軟です。 3)エコシステム:Pythonには豊富な科学コンピューティングライブラリがあり、JavaScriptには強力なフロントエンドフレームワークがあります。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

SublimeText3 中国語版
中国語版、とても使いやすい

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。
