ホームページ >ウェブフロントエンド >Vue.js >Vue3 応答関数の比較: toRef() と toRefs()
ref
は、基本的なデータ型を処理する応答性の高い API
関数です。setup
で定義された変数は宣言できます。レスポンシブ
によってラップおよび処理されていないテンプレート変数データで を直接使用すると、レスポンシブ機能がありません
つまり、データは頻繁に変更されます。ロジックはありますが、ページは更新されないため、非応答データを応答データに変える方法
toRef()
と toRefs()# を使用する必要があります。 ## これら 2 つの
componsion API
Function: value 値が別のオブジェクト内の特定の属性値を指す
ref オブジェクトを作成します。これは、オリジナルオブジェクト関連。 [関連する推奨事項:
vuejs ビデオ チュートリアル 、Web フロントエンド開発 ]
ref# を作成することです。 . ##、この方法で作成された ref
は、そのソース属性と同期され、ソース オブジェクトとの参照関係を持ちます。ソース属性の値を変更すると、
値
: const 変数名 = toRef(ソース オブジェクト、ソース オブジェクトの下のプロパティ)
例:
: レスポンシブで特定の属性を提供したい場合外部使用のためのオブジェクトを別途作成します。応答性を失いたくない場合は、prop の ref
を合成関数 に渡すことも便利です。
: toRef()は1つの属性しか処理できませんが、toRefs(source object)
は一度にバッチで処理できます<pre class="brush:js;toolbar:false;"><script setup>
import { reactive } from "vue";
const person = reactive({
name:"川川",
age: 18,
job: {
web: &#39;前端开发&#39;,
trade: &#39;互联网&#39;
}
});
</script></pre>
テンプレートにデータをレンダリングしたい場合は、次のように記述できます
{{person.name}} -{{person.age}}-{{person.job.web}}-{{person.job.trade}}
テンプレートにそれほど長く書きたくない場合は、以下に示すように、最初にテンプレートを分解できます##
<script setup> import { reactive } from "vue"; const person = reactive({ name:"川川", age: 18, job: { web: '前端开发', trade: '互联网' } }); const { name, age} = person; const { web,trade} = person.job; </script>次に、以下に示すように、テンプレートで変数を直接使用できます
{{name}}-{{age}}-{{web}}-{{trade}}ここで、変数データを変更したい場合、ロジック内のデータは変更されることがわかりますが、データはページ内の要素は更新されません。つまり、応答性が失われます。例: 次のテンプレートでは、name 属性と age 属性をそれぞれ変更します
<button @click="handleChangeAttrs">修改属性</button>ロジック コード
<script setup> import { reactive } from "vue"; const person = reactive({ name:"川川", age: 18, job: { web: '前端开发', trade: '互联网' } }); const { name, age} = person; const { web,trade} = person.job; // 这样直接操作数据是无法修改的,因为它不是一个响应式数据,只是一个纯字符串,不具备响应式 function handleChangeAttrs() { name = "itclanCoder"; age = 20; } </script>Ifデータを変更し、応答性をサポートし、非応答データを応答データに変換したい場合は、以下に示すように、
toRef(source Object、source Object の下に指定された属性) 関数
を借用する必要があります<script setup> import { reactive,toRef } from "vue"; const person = reactive({ name:"川川", age: 18, job: { web: '前端开发', trade: '互联网' } }); // 想要修改指定哪个对象具备响应式,那么就使用toRef函数处理,toRef(源对象,源对象下的某个属性) const name = toRef(person,'name'); const age = toRef(person,'age'); // 经过了toRef的处理,修改变量的值,那么就需要xx.value function handleChangeAttrs() { name.value = "itclanCoder"; age.value = 20; } </script>
テンプレートでは、依然として上記のとおりです
{{person}} {{name}}-{{age}}-{{web}}-{{trade}} <button @click="handleChangeAttrs">修改属性</button>
toRef() を使用すると、関数の処理後、応答しないデータは次のことができることがわかります。データに応答すると、ソース データも同期されます。
純粋なデータ ページの表示にのみ使用される場合は、データを変換する必要はありません。レスポンシブ データの場合、データを変更する必要がある場合は、データを変更する必要があります。 、非応答データを応答データに変換する必要があります。 は
関数
によって実装されます。 ref との違いは次のとおりです。以下に示すように、
を使用してデータを処理すると、ページの応答性とデータの更新も実現できます。ただし、toRef# とは異なります。 ##. 違いがあります。
<script setup> import { reactive,toRef } from "vue"; const person = reactive({ name:"川川", age: 18, job: { web: '前端开发', trade: '互联网' } }); // 使用ref const name = ref(person.name); const age = toRef(person.age); // 经过了toRef的处理,修改变量的值,那么就需要xx.value function handleChangeAttrs() { name.value = "itclanCoder"; age.value = 20; } </script>
データを変更すると、ページ データは更新されますが、ソース データは同期も変更もされず、参照関係はありません。
refソース オブジェクトからデータのコピーを再コピーするのと同じです
ref()受信するのは純粋な値ですtoRefs()関数
toRef()
toRefs () が非常に便利です。
toRef() と同じ機能を持ちます。複数の
ref
Syntax
:
toRefs(source object),
toRefs(person)
上記のサンプル コードのように、toRefs()shown
<script setup> import { reactive,toRefs } from "vue"; const person = reactive({ name:"川川", age: 18, job: { web: '前端开发', trade: '互联网' } }); // 通过toRefs()批量处理,此时通过解构 const {name,age} = toRefs(person); // 经过了toRef的处理,修改变量的值,那么就需要xx.value function handleChangeAttrs() { name.value = "itclanCoder"; age.value = 20; } </script>
toRefs に変更すると、合成された関数からリアクティブ オブジェクトを返す場合に便利です。これを使用すると、コンシューマ コンポーネントは、応答性を失うことなく、返されたオブジェクトを構造解除/展開できます。import { toRefs } from "vue"; function useFeatureX() { const state = reactive({ foo: 1, bar: 2 }) // 在返回时都转为ref return toRefs(state) } // 可以解构而不会失去响应性 const { foo, bar } = useFeatureX()
Notes
toRefs は、呼び出されたときにソース オブジェクト上にのみ存在します。 Enumerable プロパティ create
参照
ref
を作成する場合は、toReftoRef() 関数と toRefs() 関数が必要な理由## を使用してください。
#目的
: 応答性を失わずにオブジェクトを分解し、オブジェクト データの分解と拡散を促進します
encapsulated) 非通常のオブジェクト
Note: リアクティブ型 (つまり reactive のもの) を作成しないでください。それ自体は単なる継続です。レスポンシブ: toRef
または
を通じて非応答データを応答データに変換する機能 この データが変更されると、ページ データが更新されます。この 2 つ が使用されます (学習ビデオ共有: vuejs)入門チュートリアル、基本プログラミング ビデオ)概要
toRef()
と toRefs()
は非常に実用的で、どちらも非応答データを応答データに変換します。ソース オブジェクトとデータを同期し、参照関係を持ちます。前者は単一属性データの処理のみをサポートしますが、後者はデータのバッチ処理をサポートします。composition API
関数は非常に実用的です。実際のビジネス開発では、ページ上のデータを変更する必要がある場合、
以上がVue3 応答関数の比較: toRef() と toRefs()の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。