Vue3中響應(yīng)式解構(gòu)props的使用
1,前言
Vue3 中為了保持響應(yīng)性,始終需要以 props.x
的方式訪問這些 prop
。這意味著不能夠解構(gòu) defineProps
的返回值,因?yàn)榈玫降淖兞繉⒉皇琼憫?yīng)式的、也不會更新。
以下面的父子組件為例:
父組件
<template> <Children :count="count" /> </template> <script setup> import { ref, reactive } from "vue"; import Children from "./components/Children.vue"; const count = ref(0); </script>
子組件
<template> <div>{{ count }}</div> </template> <script setup> const props = defineProps({ count: Number, }); let { count } = props; count++; console.log(props.count); // 0,并不會發(fā)生變化 </script>
2,解決
2.1,利用插件,實(shí)現(xiàn)編譯時轉(zhuǎn)換
原本 Vue3 是支持的 reactivity-transform,后來廢棄了。但是可以通過 Vue Macros 插件 來實(shí)現(xiàn),用法如下:
1,安裝插件,并在 vite 中配置。
npm i -D @vue-macros/reactivity-transform
// vite.config.js import ReactivityTransform from '@vue-macros/reactivity-transform/vite' export default defineConfig({ plugins: [ReactivityTransform()], })
2,會在組件中自動生效。
<template> <div>{{ msg }}</div> <div>{{ count }}</div> </template> <script setup> import { watchEffect } from "vue"; const { msg, count } = defineProps({ msg: String, count: Number, }); watchEffect(() => { // 會在 props 變化時打印 console.log(msg, count); }); </script>
3,原理
先通過 vite-plugin-inspect 插件 來查看插件的中間狀態(tài)。
npm i -D vite-plugin-inspect
完整配置
// vite.config.js import { defineConfig } from "vite"; import vue from "@vitejs/plugin-vue"; import ReactivityTransform from "@vue-macros/reactivity-transform/vite"; import Inspect from "vite-plugin-inspect"; export default defineConfig({ plugins: [vue(), ReactivityTransform(), Inspect()], });
本地啟動后,訪問 http://localhost:5173/__inspect/
可檢查項(xiàng)目的模塊和棧信息。
可以看到是做了轉(zhuǎn)換,通過 __props
來訪問自然是響應(yīng)式的。
watchEffect(() => { console.log(msg, count); });
watchEffect(() => { console.log(__props.msg, __props.count); });
問題來了,這個 __props
是什么?
我們再看下 @vitejs/plugin-vue
這個插件的做了什么:會發(fā)現(xiàn)編譯單文件組件后,setup 變?yōu)楹瘮?shù),其中一個參數(shù)就是 __props
,也就是傳入的 props。
所以,我們在 vue 單文件中,也可以直接使用
__props
并不會報錯。
2.2,toRef 和 toRefs
toRef,基于響應(yīng)式對象上的一個屬性,創(chuàng)建一個對應(yīng)的 ref,這個 ref 與其源屬性保持同步:改變源屬性的值將更新 ref 的值。
toRefs,將一個響應(yīng)式對象轉(zhuǎn)換為一個普通對象,這個普通對象的每個屬性都是指向源對象相應(yīng)屬性的 ref。每個單獨(dú)的 ref 都是使用 toRef()
創(chuàng)建的。
所以,可以這樣做:
<template> <div>{{ _msg }}</div> <div>{{ msg }}</div> <div>{{ count }}</div> </template> <script setup> import { toRef, toRefs } from "vue"; const props = defineProps({ msg: String, count: Number, }); // _msg 也是響應(yīng)式的,會隨著 props.msg 改變。 const _msg = toRef(props, "msg"); // msg, count也是響應(yīng)式的,會隨著 props 改變。 const { msg, count } = toRefs(props); </script>
到此這篇關(guān)于Vue3中響應(yīng)式解構(gòu)props的使用的文章就介紹到這了,更多相關(guān)Vue3響應(yīng)式解構(gòu)props內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue require.context全局注冊組件的具體實(shí)現(xiàn)
本文主要介紹了vue require.context全局注冊組件,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-05-05基于Vue3實(shí)現(xiàn)旋轉(zhuǎn)木馬動畫效果
這篇文章主要為大家介紹了如何利用Vue3實(shí)現(xiàn)旋轉(zhuǎn)木馬的動畫效果,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Vue有一定的幫助,需要的可以參考一下2022-05-05v-if 導(dǎo)致 elementui 表單校驗(yàn)失效問題解決方案
在使用 elementui 表單的過程中,某些表單項(xiàng)需要通過 v-if 來判斷是否展示,但是這些表單項(xiàng)出現(xiàn)了檢驗(yàn)失效的問題,今天小編給大家介紹v-if 導(dǎo)致 elementui 表單校驗(yàn)失效問題解決方案,感興趣的朋友一起看看吧2024-01-01element?select必填項(xiàng)驗(yàn)證回顯問題的解決
本文主要介紹了element?select必填項(xiàng)驗(yàn)證回顯問題的解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04vue實(shí)現(xiàn)兩個區(qū)域滾動條同步滾動
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)兩個區(qū)域滾動條同步滾動,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-12-12vue.js數(shù)據(jù)加載完成前顯示原代碼{{代碼}}問題及解決
這篇文章主要介紹了vue.js數(shù)據(jù)加載完成前顯示原代碼{{代碼}}問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07vue中v-for數(shù)據(jù)狀態(tài)值變了,但是視圖沒改變的解決方案
這篇文章主要介紹了vue中v-for數(shù)據(jù)狀態(tài)值變了,但是視圖沒改變的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06