vue3中defineProps傳值使用ref響應(yīng)式失效詳解
子組件接收父組件的傳參。
父組件:
<template>
<Son :data="data"/>
</template>
<script setup>
import { ref } from "vue";
let data = ref('hello')
setTimeout(() => {
data.value = 'how are you doing'
}, 2000)
</script>
子組件:
<template>
<div>{{ msg }}</div>
</template>
<script setup>
import { ref } from "vue";
// 接受來自父組件的傳參
const props = defineProps({
data: String,
});
const msg = ref(props.data);
</script>
此時父組件改變 data 的值,子組件 msg 無法響應(yīng) data 的變化。
因為 ref 是對傳入數(shù)據(jù)的拷貝,原始值 data 的改變并不影響 msg
但 toRef 是對傳入數(shù)據(jù)的引用,原始值 data 改變會影響 msg
正確做法:
<template>
<div>{{ msg }}</div>
<div>{{ data }}</div>
</template>
<script setup>
import { ref, toRefs, toRef } from "vue";
// 接受來自父組件的傳參
const props = defineProps({
data: String,
});
// 方法1:
const msg = toRef(props, 'data');
// 方法2:
const { data } = toRefs(props);
</script>
官網(wǎng)說明

總結(jié)
到此這篇關(guān)于vue3中defineProps傳值使用ref響應(yīng)式失效的文章就介紹到這了,更多相關(guān)vue3使用ref響應(yīng)式失效內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Echarts實現(xiàn)一張圖現(xiàn)切換不同的X軸(實例代碼)
這篇文章主要介紹了Echarts 如何實現(xiàn)一張圖現(xiàn)切換不同的X軸,通過動圖給大家展示效果,實例代碼相結(jié)合給大家介紹的非常詳細,需要的朋友可以參考下2021-11-11
vue+iview?Table表格多選切換分頁保持勾選狀態(tài)
這篇文章主要為大家詳細介紹了vue+iview?Table表格多選切換分頁保持勾選狀態(tài),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-07-07
vue-admin-template配置快捷導航的代碼(標簽導航欄)
這篇文章主要介紹了vue-admin-template配置快捷導航的方法(標簽導航欄),本文通過實例代碼給大家介紹的非常詳細,對大家學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09

