ホームページ >ウェブフロントエンド >Vue.js >Vue3でprovideとinjectを使用する方法

Vue3でprovideとinjectを使用する方法

WBOY
WBOY転載
2023-05-11 23:52:041935ブラウズ

1. シーンの再現

API タイトルの意味は気にしないでください。ここでは、より一般的なシナリオを書くことから始めます。
に相当するコンポーネントの内部コードは比較的単純なのでここでは示しませんが、論理的にはこれら 3 つのコンポーネントはレイヤーごとに参照されます。

Vue3でprovideとinjectを使用する方法

対応するページ効果は次のとおりです。

Vue3でprovideとinjectを使用する方法

上に示したように、これは、プロジェクト シーン、ネストされたコンポーネントの 3 レベル。 (実際には、まだ深いレベルのネストが存在します。現時点では、3 層ネストを例として取り上げます)

わかりました。現在の要求は次のとおりです: grandpa コンポーネント内 son コンポーネント で使用するには、文字列データ "Han Zhenfang" を指定する必要があります。

賢い方なら props を思いついたはずです。早速、始めましょう。

2. Props の受け渡し

「なんと高度なことだと思いました。これは、データが父親から息子に受け渡されるシナリオではないでしょうか? props を直接渡します。この要件を完了するには。」 それでは、このようなコードを

GrandFather.vue

Vue3でprovideとinjectを使用する方法 に書きます。次に、次のことを行います。 go

Father.vue

コンポーネントはこのデータを受信します。そこで、この値を受け取るために Father.vue コンポーネントで props を定義しました。

Vue3でprovideとinjectを使用する方法ページを見てみましょう

Vue3でprovideとinjectを使用する方法問題ありません。

Dad コンポーネント

は完了しました。受け取った。ただし、タスクがまだ完了していないことを忘れないでください。要件は son コンポーネント によって使用されることなので、 すぐに渡します。

Vue3でprovideとinjectを使用する方法これで、

Children.vue

コンポーネントは次のようになります。

Vue3でprovideとinjectを使用する方法ページの効果は次のとおりです。

Vue3でprovideとinjectを使用する方法最終的に、

son コンポーネント

確かに得られました。 これを書いているときに何か間違ったことを見つけましたか? ????

実際、

Dad コンポーネント

はこれらのプロパティを知る必要はまったくなく、単に パッシングマイク として機能します。このコンポーネントがこの 1 つのシナリオでのみ使用される場合は問題ありませんが、Dad コンポーネントを 2 番目の場所で再利用したい場合は、問題が発生することがわかります。この Dad コンポーネント message1 という props を指定する必要がありますが、実際には、この message1Dad コンポーネント # ではありません##内部で使用される属性。 これを書いていると、もう 1 つのレイヤーを渡すだけでコンポーネントの再利用性が非常に悪くなることがわかりました。これはまだ 3 レベルのネストしかないシーンです。4 番目のレベルに到達すると、徐々に物事が難しくなり始めることがわかります。props

は良い選択ではないようです。

これを考えると、もっと良い解決策はないだろうかと考え始めるでしょう。それが今日の主役、provide

inject です。 3. 提供と注入

まず、API の名前を覚えないでください。作成者には名前を付けた理由が必要です。多くの場合、最初にこれら 2 つの単語の意味を確認します。

Vue3でprovideとinjectを使用する方法

これら 2 つの単語の意味だけで、大まかな意味は推測できると思います。1 つは Vue3でprovideとinjectを使用する方法provide

A です。特定の値、もう 1 つは

登録 この値を受信することです。 それでは、これら 2 つの API をどのように正しく使用するかという疑問が生じます。これは実際には非常に簡単です。おじいちゃんコンポーネントに戻って、彼の元の外観を復元しましょう。

必要な手順は 2 つだけです:

Vue3でprovideとinjectを使用する方法

もしかしたら驚かれるかもしれませんが、これだけですか?はっきり言っておきますが、はい、これで大丈夫です。

最後のステップは、son コンポーネント に移動して、それを受け取って使用することです。これで完了です。

Vue3でprovideとinjectを使用する方法

ページの効果を見てみましょう:

Vue3でprovideとinjectを使用する方法

データが正常に取得されただけでなく、キーも取得されました。私たちのDad Component はクリーンであり、他の場所の参照に影響を与えません。

Vue3でprovideとinjectを使用する方法

戻って、provide の使用法を説明しましょう。 provide 2 つのパラメータを受け入れます。最初のパラメータは一意の識別子である必要があり (コンポーネント内の変数と同じ名前は許可されません)、2 番目のパラメータは渡される値です。
このように理解することもできます。今、おじいちゃんコンポーネントが拡声器を持って叫んでいます????:「誰が「Han Zhenfang」を望んでいるのか、誰が望んでいるのか」 #汉正方’、価格は安く、必要なのは「メッセージ’」1つだけです。

この時点で

息子コンポーネントはそのニュースを聞いて「欲しい、欲しい!!」と叫んだため、すぐにメッセージを挿入します。 」。

Vue3でprovideとinjectを使用する方法

注:

受け入れるために使用する変数名はランダムに選択されるため、前の変数名と一致している必要はありません。

Vue3でprovideとinjectを使用する方法そして、

Dad コンポーネント

はそれをまったく必要としないため、inject はまったく必要ありません。 そして

inject

を使用すると、hiding 動作も可能になります。これはどういう意味ですか? この son コンポーネント も他の場所で再利用する必要があるが、その grandfather コンポーネント または には祖父コンポーネント がまったくないとします。 2 番目のパラメータは suibian のデフォルト値として使用されます。

Vue3でprovideとinjectを使用する方法テストしてみましょう。まず、

grandpa コンポーネント

provide 動作をキャンセルします。

Vue3でprovideとinjectを使用する方法ご覧のとおり、このページには

Understanding

データが正しく表示されています。

Vue3でprovideとinjectを使用する方法4. Provide

provide

の高度な使用法は、単に string 型を提供するだけではありません。データだけです。Grandpa Component でレスポンシブ データを宣言してみましょう。

Vue3でprovideとinjectを使用する方法

son コンポーネント

が大きくなったので、数値の増加も制御したいと表示されますが、大丈夫ですか? おじいちゃんコンポーネントは、がとても気に入っているので、が使用できるメソッドを提供しています。

Vue3でprovideとinjectを使用する方法#Son コンポーネント

本当に自分で制御できますか?その子は本当に成長したのでしょうか?

Vue3でprovideとinjectを使用する方法son コンポーネント

が実際に

成長したことがわかります (成功した inject を参照) #Grandpa コンポーネント provide function)振り返って忘れないでください。2 番目のパラメーターは隠蔽行動です。おじいちゃんが関数を提供しない場合は、動作のないアロー関数を自分で使用します。それだけです。

5. ソースコード

Vue3でprovideとinjectを使用する方法

Grandpa コンポーネント コード

<script lang="ts" setup>
// 这是爷爷组件
import { ref } from "vue";
import { provide } from "vue";

import Father from "./Father.vue";

const count = ref<number>(0);
function add() {
  count.value = count.value + 1;
}

provide("message", count);
provide("messageAdd", add); //我把 add 也同时提供给儿子组件
</script>
<template>
  <div class="w-full h-[300px] bg-[black]">
    <span class="text-white text-[20px]">爷爷组件</span>
    <button @click="add">message+1</button>
    <Father />
  </div>
</template>

Father コンポーネント コード##

<script lang="ts" setup>
// 这是父亲组件
import Children from "./Children.vue";
</script>
<template>
  <div class="w-[70%] h-[270px] bg-[pink]">
    <span class="text-[black] text-[20px]">爸爸组件</span>
    <span class="text-[black] text-[15px]"></span>
    <Children />
  </div>
</template>

息子コンポーネント コード

<script lang="ts" setup>
// 这是儿子组件

import { inject } from "vue";

const suibian = inject("message", "假如爷爷没提供没有的话就用我");
const add = inject("messageAdd", () => {});
</script>
<template>
  <div class="w-[70%] h-[230px] bg-[white]">
    <span class="text-[black] text-[20px]">儿子组件</span>
    <span class="text-[black] text-[10px]">{{ suibian }}</span>
    <button @click="add">长大了,我自己+1</button>
  </div>
</template>

6. 考えるための質問

今なら祖父コンポーネント

親コンポーネント

も同じキーワード値を提供します。

息子コンポーネント 最終的には誰のコンポーネントが使用されますか?

GrandFather.vue: =>provide("メッセージ","おじいちゃんコンポーネントによる提供");
Father.vue: =>provide("メッセージ","親コンポーネントによって提供されます")

Children.vue:=> inject("message","Whoose one do I use?")

以上がVue3でprovideとinjectを使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。