Skip to content

Vue Reactive 使用筆記

vue-reactive-cheat-sheet

使用 Vue 定義資料時,到底要用 ref 還是 reactive 是一個很常見的問題

不過官方文件推薦使用 ref 就行,所以其實也不是甚麼大問題了。( •̀ ω •́ )✧

一般情況下的確 ref 更好,坑也相對少一點,且更容易拆分邏輯,詳細說明可以看看尤大訪談

所以 reactive 真的沒用用途了嗎?這篇文章來記錄一下 reactive 的用法。

不定期更新,會持續補充用法。( ´ ▽ ` )ノ

解包響應式資料

以 VueUse 的 useElementBounding 為例。

此 API 可以取得多個 element 的 bounding 資料,只需要寬高資料,就可以只取出寬高:

ts
const { width, height } = useElementBounding(el)

但是有時候會需要全部都要,可能會這樣寫:

ts
const bounding = useElementBounding(el)

這時候因為內部資料還是 ref,所以取值需要 .value(例如 bounding.width.value),這個時候就可以先用 reactive 包起來:

ts
const bounding = reactive(useElementBounding(el))

包起來後,就可以 bounding.width,不用 value 了

以上用法供大家參考,若有錯誤還請大家多多指教。

總結 🐟

  • 官方推薦使用 ref
  • reactive 可以用在解包響應式資料
  • 有其他用法也歡迎補充 (´▽`ʃ♡ƪ)