簡單談?wù)刅ue3中的ref和reactive
一、是什么?
ref和reactive是Vue3中用來實(shí)現(xiàn)數(shù)據(jù)響應(yīng)式的API
一般情況下,ref
定義基本數(shù)據(jù)類型,reactive
定義引用數(shù)據(jù)類型
(我喜歡用它來定義對(duì)象,不用它定義數(shù)組,原因后面講)
我理解的ref本質(zhì)上是reactive的再封裝
二、先聊reactive
reactive定義引用數(shù)據(jù)類型(以對(duì)象和數(shù)組舉例),它能夠?qū)?fù)雜數(shù)據(jù)類型的內(nèi)部屬性或者數(shù)據(jù)項(xiàng)聲明為響應(yīng)式數(shù)據(jù),所以reactive的響應(yīng)式是深層次的,其底層是通過ES6的Proxy
來實(shí)現(xiàn)數(shù)據(jù)響應(yīng)式,相對(duì)于Vue2的Object.defineProperty
,具有能監(jiān)聽增刪操作,能監(jiān)聽對(duì)象屬性的變化等優(yōu)點(diǎn)
使用reactive定義對(duì)象數(shù)據(jù)類型舉例
const paginationConfig = reactive({ pageNum: 1, pageSize: 10 }) // 定義 const onChange = () => { paginationConfig.pageNum = 2 // js使用 paginationConfig.pageSize = 20 // js使用 }
<!-- Vue3模板引用使用 --> <a-pagination v-model:current="paginationConfig.pageNum"></a-pagination>
若用reactive定義基本數(shù)據(jù)類型,Vue3會(huì)報(bào)警告錯(cuò)誤,如圖
const str = reactive('我是字符串')
分析Vue3源碼可知,使用reactive定義響應(yīng)式數(shù)據(jù)時(shí),若數(shù)據(jù)不是對(duì)象類型直接就返回了,就不會(huì)進(jìn)行后續(xù)的數(shù)據(jù)響應(yīng)式處理了,這也就是我只用reactive定義對(duì)象型響應(yīng)式數(shù)據(jù)的原因,那數(shù)組類型數(shù)據(jù)怎么辦呢?答案在下文中可以找到
三、再聊ref
為什么我會(huì)理解成ref是reactive的再封裝,因?yàn)樵趓ef的底層源碼里最終還是reactive()來實(shí)現(xiàn)的
由源碼分析得知,如果是對(duì)象類型,底層走的還是reactive()的邏輯,另外我們知道,使用ref定義基本數(shù)據(jù)類型時(shí),在腳本里使用時(shí),需要加.value
后綴,然而在模板里不需要,這是因?yàn)閂ue3會(huì)自動(dòng)幫你加上,這就使得ref相比reactive更加簡單
let num = ref(0) // 定義 let isShow = ref(false) // 定義 const onChange = () => { num.value++ // js使用 isShow.value = true // js使用 }
<!-- Vue3模板引用使用 --> <a-modal v-model:visible="isShow"></a-modal>
四、ref和reactive定義數(shù)組對(duì)比
使用ref定義數(shù)組舉例如下
const tableData = ref([]) // 定義 const getTableData = async () => { const { data } = await getTableDataApi() // 模擬接口獲取表格數(shù)據(jù) tableData.value = data // 修改 }
<!-- Vue3模板引用使用 --> <a-table v-model:dataSource="tableData"></a-table>
圖中以我們常用的表格數(shù)據(jù)舉例,可以看到,ref定義數(shù)組與定義基本數(shù)據(jù)類型沒什么差別,接下來看看reactive
const tableData = reactive([]) // 定義 const getTableData = async () => { const { data } = await getTableDataApi() // 模擬接口獲取表格數(shù)據(jù) tableData = data // 修改,錯(cuò)誤示例,這樣賦值會(huì)使tableData失去響應(yīng)式 }
<!-- Vue3模板引用使用 --> <a-table v-model:dataSource="tableData"></a-table>
需要注意的是,使用 tableData = data 的修改方式會(huì)造成 tableData 響應(yīng)式丟失,解決方法如下(供參考)
// 方法一:改為 ref 定義 const tableData = ref([]) const getTableData = async () => { const { data } = await getTableDataApi() tableData.value = data // 使用.value重新賦值 } // 方法二:使用 push 方法 const tableData = reactive([]) const getTableData = async () => { const { data } = await getTableDataApi() tableData.push(...data) // 先使用...將data解構(gòu),再使用push方法 } // 方法三:定義時(shí)數(shù)組外層嵌套一個(gè)對(duì)象 const tableData = reactive({ list:[] }) const getTableData = async () => { const { data } = await getTableDataApi() tableData.list = data // 通過訪問list屬性重新賦值 } // 方法四:賦值前再包一層 reactive const tableData = reactive([]) const getTableData = async () => { const { data } = await getTableDataApi() tableData = reactive(data) // 賦值前再包一層reactive }
五、對(duì)比總結(jié)
- ref用于定義基本類型和引用類型,reactive僅用于定義引用類型
- reactive只能用于定義引用數(shù)據(jù)類型的原因在于內(nèi)部是通過ES6的Proxy實(shí)現(xiàn)響應(yīng)式的,而Proxy不適用于基本數(shù)據(jù)類型
- ref定義對(duì)象時(shí),底層會(huì)通過reactive轉(zhuǎn)換成具有深層次的響應(yīng)式對(duì)象,所以ref本質(zhì)上是reactive的再封裝
- 在腳本里使用ref定義的數(shù)據(jù)時(shí),記得加.value后綴
- 在定義數(shù)組時(shí),建議使用ref,從而可避免reactive定義時(shí)值修改導(dǎo)致的響應(yīng)式丟失問題
總結(jié)
到此這篇關(guān)于簡單談?wù)刅ue3中ref和reactive的文章就介紹到這了,更多相關(guān)Vue3中ref和reactive內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vue3中的ref和reactive定義數(shù)組方式
- vue3+ts數(shù)組去重方及reactive/ref響應(yīng)式顯示流程分析
- Vue3關(guān)于響應(yīng)式數(shù)據(jù)類型詳解(ref、reactive、toRef、及toRefs)
- vue3中如何使用ref和reactive定義和修改響應(yīng)式數(shù)據(jù)(最新推薦)
- 詳解Vue3中shallowRef和shallowReactive的使用
- 詳解Vue3中ref和reactive函數(shù)的使用
- vue3如何定義變量及ref、reactive、toRefs特性說明
- Vue3.0中Ref與Reactive的區(qū)別示例詳析
- vue3中reactive和ref函數(shù)及對(duì)比分析
相關(guān)文章
移動(dòng)端調(diào)試神器vConsole使用詳解
vConsole?是框架無關(guān)的,可以在?Vue、React?或其他任何框架中使用,今天通過本文給大家介紹移動(dòng)端調(diào)試神器vConsole使用,感興趣的朋友一起看看吧2022-04-04vue 中基于html5 drag drap的拖放效果案例分析
本文通過三個(gè)案例給大家介紹了vue 中基于html5 drag drap的拖放效果 ,需要的朋友可以參考下2018-11-11vue2中seo時(shí)使用vue-meta-info的方法
這篇文章主要介紹了vue2中seo時(shí)使用vue-meta-info,本文通過實(shí)例代碼給大家詳細(xì)講解,文末給大家補(bǔ)充介紹了vue seo管理 vue-meta-info 動(dòng)態(tài)設(shè)置meta和title的相關(guān)知識(shí),需要的朋友可以參考下2022-10-10vue element-ui實(shí)現(xiàn)el-table表格多選以及回顯方式
這篇文章主要介紹了vue element-ui實(shí)現(xiàn)el-table表格多選以及回顯方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07vue中使用elementUI組件手動(dòng)上傳圖片功能
Vue是一套構(gòu)建用戶界面的框架, 開發(fā)只需要關(guān)注視圖層, 它不僅易于上手,還便于與第三方庫或既有項(xiàng)目的整合。這篇文章主要介紹了vue中使用elementUI組件手動(dòng)上傳圖片,需要的朋友可以參考下2019-12-12