91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue3中的ref和reactive如何使用

發布時間:2023-05-18 16:40:43 來源:億速云 閱讀:105 作者:iii 欄目:編程語言

這篇文章主要講解了“Vue3中的ref和reactive如何使用”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Vue3中的ref和reactive如何使用”吧!

一、是什么

ref和reactive是Vue3中用來實現數據響應式的API

一般情況下,ref定義基本數據類型,reactive定義引用數據類型

二、先聊reactive

reactive定義引用數據類型(以對象和數組舉例),它能夠將復雜數據類型的內部屬性或者數據項聲明為響應式數據,所以reactive的響應式是深層次的,其底層是通過ES6的Proxy來實現數據響應式,相對于Vue2的Object.defineProperty,具有能監聽增刪操作,能監聽對象屬性的變化等優點

使用reactive定義對象數據類型舉例

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定義基本數據類型,Vue3會報警告錯誤,如圖

const str = reactive('我是字符串')

Vue3中的ref和reactive如何使用

Vue3中的ref和reactive如何使用

分析Vue3源碼可知,使用reactive定義響應式數據時,若數據不是對象類型直接就返回了,就不會進行后續的數據響應式處理了,這也就是我只用reactive定義對象型響應式數據的原因,那數組類型數據怎么辦呢?答案在下文中可以找到

三、再聊ref

為什么我會理解成ref是reactive的再封裝,因為在ref的底層源碼里最終還是reactive()來實現的

Vue3中的ref和reactive如何使用

Vue3中的ref和reactive如何使用

由源碼分析得知,如果是對象類型,底層走的還是reactive()的邏輯,另外我們知道,使用ref定義基本數據類型時,在腳本里使用時,需要加.value后綴,然而在模板里不需要,這是因為Vue3會自動幫你加上,這就使得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定義數組對比

使用ref定義數組舉例如下

const tableData = ref([]) // 定義

const getTableData = async () => {
	const { data } = await getTableDataApi() // 模擬接口獲取表格數據
	tableData.value = data // 修改
}
<!-- Vue3模板引用使用 -->
<a-table v-model:dataSource="tableData"></a-table>

圖中以我們常用的表格數據舉例,可以看到,ref定義數組與定義基本數據類型沒什么差別,接下來看看reactive

const tableData = reactive([]) // 定義

const getTableData = async () => {
	const { data } = await getTableDataApi() // 模擬接口獲取表格數據
	tableData = data // 修改,錯誤示例,這樣賦值會使tableData失去響應式
}
<!-- Vue3模板引用使用 -->
<a-table v-model:dataSource="tableData"></a-table>

需要注意的是,使用 tableData = data 的修改方式會造成 tableData 響應式丟失,解決方法如下(供參考)

// 方法一:改為 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解構,再使用push方法
}
// 方法三:定義時數組外層嵌套一個對象
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
}

感謝各位的閱讀,以上就是“Vue3中的ref和reactive如何使用”的內容了,經過本文的學習后,相信大家對Vue3中的ref和reactive如何使用這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

望城县| 乌海市| 卓资县| 德保县| 莱州市| 铁岭市| 耿马| 庆云县| 左云县| 华蓥市| 宁都县| 静乐县| 兴业县| 元江| 康保县| 饶阳县| 安化县| 普格县| 博客| 昔阳县| 桓台县| 桂东县| 岳池县| 郴州市| 沅江市| 武义县| 武强县| 镇宁| 米林县| 会理县| 武鸣县| 永福县| 和龙市| 南昌市| 汽车| 谷城县| 方正县| 宜川县| 资溪县| 丰原市| 宜州市|