Vue3組合式函數(shù)Composable實(shí)戰(zhàn)ref和unref使用
正文
本文為翻譯文章,部分內(nèi)容難免理解有偏差,如有錯(cuò)誤歡迎大家指正。原文鏈接見文章末尾。
在使用Vue.js中的組合式時(shí),有時(shí)你已經(jīng)有了一個(gè)想要使用的ref
,而有時(shí)你沒有。本文將介紹一種模式,讓你可以以兩種方式使用組合式,從而在編寫應(yīng)用程序時(shí)提供更多的靈活性。
本篇是這個(gè)系列文章的第二篇,全部涵蓋內(nèi)容如下:
- 1.如何通過選項(xiàng)對(duì)象參數(shù)使您的組合更加可配置;
- 2.使用ref和unref使我們的參數(shù)更加靈活;?? 本篇主題
- 3.如何使你的返回值更有用;
- 4.為什么從接口定義開始可以使你的組合式函數(shù)更強(qiáng)大;
- 5.如何使用異步代碼而無需“等待” - 使您的代碼更易于理解;
使用ref和unref來實(shí)現(xiàn)更靈活的參數(shù)傳遞
通常,組合式API需要某些類型的參數(shù)作為輸入,通常會(huì)使用到響應(yīng)式變量參數(shù)。它也可以是原始的Javascript類型,如字符串,數(shù)字或?qū)ο?。但是,為了使組合式更具靈活性和可重用性,我們會(huì)希望它可以接受任意類型的參數(shù),并在運(yùn)行時(shí)將其轉(zhuǎn)換為所需的類型。
// Works if we give it a ref we already have const countRef = ref(2); useCount(countRef); // Also works if we give it just a number const countRef = useCount(2);
我們上篇里面提到的useTitle
也適用于這種模式。當(dāng)我們傳入一個(gè)ref
的時(shí)候,頁面的標(biāo)題將會(huì)被設(shè)置成這個(gè)ref
的value
。
const title = ref('這里是標(biāo)題'); useTitle(title); title.value = '這是一個(gè)新標(biāo)題';
如果我們傳入一個(gè)字符串變量的話,它將會(huì)創(chuàng)建一個(gè)新的ref和標(biāo)題進(jìn)行關(guān)聯(lián):
const title = useTitle('這里是標(biāo)題'); title.value = '這是一個(gè)新標(biāo)題';
上面的例子可能看起來區(qū)別不大,但是,在我們使用到一些方法或者組合式API的時(shí)候,我們可能會(huì)有不同的引用來源,從而這個(gè)組合式可以適應(yīng)不同的情況。
下面讓我們來看一下如何在我們的組合式中使用這種模式。
在組合式中實(shí)現(xiàn)靈活的參數(shù)
想實(shí)現(xiàn)靈活的參數(shù)模式,我們需要使用到ref
和unref
方法在參數(shù)上面。
// When we need to use a ref in the composable export default useMyComposable(input) { const ref = ref(input); } // When we need to use a raw value in the composable export default useMyComposable(input) { const rawValue = unref(input); }
如果是非響應(yīng)式的參數(shù)變量的話,ref
方法會(huì)創(chuàng)建一個(gè)新的ref
變量給我們;如果是響應(yīng)式的話,它會(huì)直接將對(duì)應(yīng)的變量返回給我們。
// Create a new ref const myRef = ref(0); // Get the same ref back assert(myRef === ref(myRef));
unref
方法類似,只不過它是將變量的真實(shí)值返回給我們
// Unwrap to get the inner value const value = unref(myRef); // Returns the same primitive value assert(value === unref(value));
下面讓我們看看在VueUse
中使用這種模式的例子。
舉例-useTitle
讓我們繼續(xù)來看下我們已經(jīng)熟悉的useTitle
方法。它允許我們傳入一個(gè)字符串或者是響應(yīng)式字符串變量:
// 傳入字符串變量 const titleRef = useTitle('Initial title'); // 傳入響應(yīng)式字符串變量 const titleRef = ref('Initial title'); useTitle(titleRef);
在它的源碼中,我們可以看出,它通過ref
方法來處理我們傳入的變量
// ... const title = ref(newTitle ?? document?.title ?? null) // ...
它使用到了JavaScript中的nullish coalescing(空值合并)運(yùn)算符
,其語法為“??”,意思是“如果左側(cè)的值為null
或undefined
,則使用右側(cè)的值”。在代碼中,如果newTitle
未定義,則使用document.title
,如果document.title
也未定義,則使用null
。這個(gè)運(yùn)算符可以用于簡(jiǎn)化代碼中的條件判斷。
另外,useTitle
的類型定義中還使用到了TypeScript 中的 MaybeRef 類型,它可以是 string
類型或 Ref<string>
類型。其中 Ref<T>
是一個(gè)帶有 T
類型值的 ref
。
type MaybeRef<T> = T | Ref<T>
舉例-useCssVar
useCssVar
允許我們獲取到CSS變量的值并在應(yīng)用程序中使用它。和useTitle
不同的是,我們需要傳入一個(gè)string類型的值,來查詢對(duì)應(yīng)DOM上面的CSS變量。通過unref
方法,來處理傳入的變量 - string
類型或者是一個(gè)ref
:
// Using a string const backgroundColor = useCssVar('--background-color'); // Using a ref const cssVarRef = ref('--background-color'); const backgroundColor = useCssVar(cssVarRef);
通過查看它的源碼,我們可以看出它使用了unRef
方法來處理傳入的參數(shù)。而且,它還使用了一個(gè)輔助函數(shù)unrefElement
,用于確保獲取的是 DOM
元素而不是 Vue
實(shí)例。
在VueUse
中很多組合式方法都使用了這個(gè)模式,如果你想深入研究的話,選擇一個(gè)感興趣的去看它的源碼吧。
小結(jié)
本篇我們主要介紹了Vue.js中的可組合函數(shù)(composables)的第二個(gè)模式。該模式使用ref
和unref
函數(shù)來更靈活地使用參數(shù),使可組合函數(shù)能夠適應(yīng)不同的使用情況。
還介紹了VueUse庫(kù)如何實(shí)現(xiàn)這種模式,并舉例說明了useTitle和useCssVar可組合函數(shù)如何使用ref和unref函數(shù)。
下一篇中,我們將會(huì)介紹另一種模式,該模式可以根據(jù)需要返回單個(gè)值或?qū)ο?,從而使可組合函數(shù)更易于使用。該模式可以使可組合函數(shù)更簡(jiǎn)單易用,尤其是在大多數(shù)情況下只需要單個(gè)值的情況下。
原文鏈接: # Coding Better Composables (2/5)
以上就是Vue3組合式函數(shù)Composable實(shí)戰(zhàn)ref和unref使用的詳細(xì)內(nèi)容,更多關(guān)于Vue3組合式函數(shù)ref unref的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Vue使用js-audio-recorder實(shí)現(xiàn)錄制,播放與下載音頻功能
這篇文章主要為大家詳細(xì)介紹了Vue如何使用js-audio-recorder實(shí)現(xiàn)錄制,播放與下載音頻功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解下2023-12-12vue打印功能實(shí)現(xiàn)的兩種方法總結(jié)
在項(xiàng)目中,有時(shí)需要打印頁面的表格,所以下面這篇文章主要給大家介紹了關(guān)于vue打印功能實(shí)現(xiàn)的兩種方法,以及批量打印的完整代碼,需要的朋友可以參考下2021-06-06vue3如何使用postcss-px-to-viewport適配屏幕
這篇文章主要介紹了vue3如何使用postcss-px-to-viewport適配屏幕問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03淺談Vuex的this.$store.commit和在Vue項(xiàng)目中引用公共方法
這篇文章主要介紹了淺談Vuex的this.$store.commit和在Vue項(xiàng)目中引用公共方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-07-07