欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3選項(xiàng)式api如何監(jiān)控?cái)?shù)組變化

 更新時(shí)間:2024年06月07日 08:59:52   作者:loggers_kid  
這篇文章主要介紹了vue3選項(xiàng)式api如何監(jiān)控?cái)?shù)組變化問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

1、vue3數(shù)組監(jiān)控的問題

vue3中使用監(jiān)控器 watch 能夠完成一些基本類型數(shù)據(jù)的監(jiān)控,但是如果碰到復(fù)雜類型的數(shù)據(jù),除了直接給變量的賦值操作,元素的添加和改變(包括長(zhǎng)度變化)普通watch是監(jiān)控不到的。

這里的復(fù)雜類型包括對(duì)象和數(shù)組。

使用 vue3給出一個(gè)示例程序:

<template>
	<div>
		<div><button @click="change">按鈕1</button></div>
        <div><button @click="change2">按鈕2</button></div>
	</div>
</template>
 
<script>
	export default{
		data() {
			return {
				msg1: 1,
				msg2: "test",
				msg3: ["Tom","Jerry","Spiker"],
				msg4: {a: "你好"}
			}
		},
		methods: {
			change(){
				this.msg1 += 1
				this.msg2 += 1
				this.msg3.push("Rose")
				this.msg4.b = "你也好"
			},
            change2(){
				this.msg3 = ["Tom and Jerry"]
				this.msg4 = {a: "你也好!"}
			}
		},
		watch: {
			msg1 (newValue, oldValue) {
				console.log("msg1 change")
			},
			msg2 (newValue, oldValue) {
				console.log("msg2 change")
			},
			msg3 (newValue, oldValue) {
				console.log("msg3 change")
			},
			msg4 (newValue, oldValue) {
				console.log("msg4 change")
			}
		}
	}
</script>
 
<style>
</style>

點(diǎn)擊按鈕1,程序的打印結(jié)果為:

說明 msg3和 msg4變量的元素添加確實(shí)沒有監(jiān)聽到。

點(diǎn)擊按鈕2,程序打印結(jié)果為:

說明數(shù)組和對(duì)象的直接賦值操作是可以被 watch 監(jiān)聽到的。

那么為什么普通 watch 沒有提供對(duì)數(shù)組和對(duì)象的元素變化的監(jiān)聽呢? 問題原文。簡(jiǎn)而言之就是將基本類型的數(shù)據(jù)和復(fù)雜類型的數(shù)據(jù)做了區(qū)分,以避免復(fù)雜數(shù)據(jù)對(duì)于性能的損耗(個(gè)人理解)。

2、解決方案

2.1 vue版本

網(wǎng)上有些文章給出的解決辦法是通過 this.$set() 來指定數(shù)組下標(biāo)元素的變化,那么這樣就可以直接使用 watch 來進(jìn)行監(jiān)聽。但是沒有寫清楚,這是vue2的解決辦法(也可能那些博主在寫那些文章時(shí)vue3還沒有發(fā)布)。

總之,vue3響應(yīng)式數(shù)據(jù)的實(shí)現(xiàn)方法是和vue2不同的。比如上面的代碼,如果是vue2的話,是可以實(shí)現(xiàn) arr.push() 方法的監(jiān)控,但是下標(biāo)元素的改變,比如 arr[ index] = item 是實(shí)現(xiàn)不了的,所以需要監(jiān)控的數(shù)組變量使用 this.$set() 來改變下標(biāo)元素才能被 watch 監(jiān)控到。

這篇文章只給出功能描述和寫法,想弄清楚這種差別原因的需要去研究 vue2和vue3響應(yīng)式實(shí)現(xiàn)原理的不同。喜歡的同學(xué)可以去研究一下源碼。

2.2 vue3選項(xiàng)式api深度監(jiān)控的寫法

vue3的數(shù)據(jù)響應(yīng)是基于代理 proxy,所以取消了 this.$set()的使用,但是引入深度監(jiān)控的寫法。所以 vue3可以通過 watch的深度監(jiān)控來實(shí)現(xiàn)數(shù)組和對(duì)象變化的響應(yīng)。

這里修改一下上面的代碼,將 msg3和 msg4的監(jiān)控器改成:

msg3: {
	deep: true,
	handler(newValue, oldValue) {
		console.log("msg3 change")
	}
},
msg4 : {
	deep: true,
	handler(newValue, oldValue) {
		console.log("msg4 change")
    }
}

重新點(diǎn)擊一下按鈕1 ,打印結(jié)果變成:

實(shí)現(xiàn)了對(duì)于數(shù)組和對(duì)象的內(nèi)容元素監(jiān)控。

3、結(jié)論

vue3要實(shí)現(xiàn)數(shù)組監(jiān)控的話,可以使用深度監(jiān)控來實(shí)現(xiàn)。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue3.0的優(yōu)化總結(jié)

    Vue3.0的優(yōu)化總結(jié)

    在本篇文章里小編給大家整理的是一篇關(guān)于Vue3.0的優(yōu)化總結(jié)內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。
    2020-10-10
  • Element-UI日期選擇器(選擇日期范圍)禁用未來日期實(shí)現(xiàn)代碼

    Element-UI日期選擇器(選擇日期范圍)禁用未來日期實(shí)現(xiàn)代碼

    我們?cè)诰W(wǎng)頁開發(fā)時(shí)通常需要用到一些日期組件來方便用戶選擇時(shí)間,其中element日期組件是一個(gè)非常好用的工具,這篇文章主要給大家介紹了關(guān)于Element-UI日期選擇器(選擇日期范圍)禁用未來日期的相關(guān)資料,需要的朋友可以參考下
    2024-02-02
  • Vue3 組合式函數(shù)Composable最佳實(shí)戰(zhàn)

    Vue3 組合式函數(shù)Composable最佳實(shí)戰(zhàn)

    這篇文章主要為大家介紹了Vue3 組合式函數(shù)Composable最佳實(shí)戰(zhàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • Vue項(xiàng)目中如何封裝axios(統(tǒng)一管理http請(qǐng)求)

    Vue項(xiàng)目中如何封裝axios(統(tǒng)一管理http請(qǐng)求)

    這篇文章主要給大家介紹了關(guān)于Vue項(xiàng)目中如何封裝axios(統(tǒng)一管理http請(qǐng)求)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • 使用vue-router切換組件時(shí)使組件不銷毀問題

    使用vue-router切換組件時(shí)使組件不銷毀問題

    這篇文章主要介紹了使用vue-router切換組件時(shí)使組件不銷毀問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue導(dǎo)出excel表格的新手詳細(xì)教程

    vue導(dǎo)出excel表格的新手詳細(xì)教程

    相信大家做項(xiàng)目的時(shí)候,功能中都有導(dǎo)出模塊,下面這篇文章主要給大家介紹了關(guān)于vue導(dǎo)出excel表格的詳細(xì)教程,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • vue.js,ajax渲染頁面的實(shí)例

    vue.js,ajax渲染頁面的實(shí)例

    下面小編就為大家分享一篇vue.js,ajax渲染頁面的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • Vue3實(shí)現(xiàn)表單輸入的雙向綁定的示例代碼

    Vue3實(shí)現(xiàn)表單輸入的雙向綁定的示例代碼

    Vue.js 是一個(gè)漸進(jìn)式的JavaScript框架,廣泛用于構(gòu)建交互式用戶界面,在 Vue 中,雙向綁定是一項(xiàng)非常核心的概念,尤其是在處理表單輸入時(shí),它使得數(shù)據(jù)和用戶界面之間的互動(dòng)變得簡(jiǎn)單又高效,在本篇博客中,我們將深入探討如何在 Vue 3 中實(shí)現(xiàn)表單輸入的雙向綁定
    2025-01-01
  • uniapp前端實(shí)現(xiàn)微信支付功能全過程(小程序、公眾號(hào)H5、app)

    uniapp前端實(shí)現(xiàn)微信支付功能全過程(小程序、公眾號(hào)H5、app)

    這篇文章主要介紹了uniapp前端實(shí)現(xiàn)微信支付功能的相關(guān)資料,通過uniapp開發(fā)跨平臺(tái)應(yīng)用時(shí),需要處理不同平臺(tái)的支付方式,包括微信小程序支付、公眾號(hào)H5支付和App支付,需要的朋友可以參考下
    2024-09-09
  • Vue中keep-alive 實(shí)現(xiàn)后退不刷新并保持滾動(dòng)位置

    Vue中keep-alive 實(shí)現(xiàn)后退不刷新并保持滾動(dòng)位置

    這篇文章主要介紹了Vue中keep-alive 實(shí)現(xiàn)后退不刷新并保持滾動(dòng)位置的相關(guān)知識(shí),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-03-03

最新評(píng)論