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

前端vue如何監(jiān)聽(tīng)對(duì)象或者數(shù)組某個(gè)屬性的變化詳解

 更新時(shí)間:2024年03月20日 15:07:24   作者:星辰迷上大海  
這篇文章主要給大家介紹了關(guān)于前端vue如何監(jiān)聽(tīng)對(duì)象或者數(shù)組某個(gè)屬性的變化的相關(guān)資料,在Vue中你可以使用watch或者computed來(lái)監(jiān)聽(tīng)對(duì)象或數(shù)組某個(gè)屬性的變化,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

在 Vue 中,你可以使用 watch 或者 computed 來(lái)監(jiān)聽(tīng)對(duì)象或數(shù)組某個(gè)屬性的變化。但是,如果直接設(shè)置數(shù)組的某一項(xiàng)的值,或者直接設(shè)置對(duì)象的某個(gè)屬性值,這個(gè)時(shí)候,你會(huì)發(fā)現(xiàn)頁(yè)面并沒(méi)有更新。這是因?yàn)?nbsp;Object.defineProperty() 限制,監(jiān)聽(tīng)不到變化。

使用 watch

watch 是 Vue 提供的一個(gè) API,用于監(jiān)聽(tīng)對(duì)象或者數(shù)組某個(gè)屬性的變化。當(dāng)被監(jiān)聽(tīng)的屬性發(fā)生變化時(shí),watch 中的處理函數(shù)會(huì)被調(diào)用。下面是一個(gè)示例代碼:

data() {
  return {
    myObject: {
      prop: 'initial value'
    }
  };
},
watch: {
  'myObject.prop': function(newVal, oldVal) {
    // 在這里處理屬性變化
  }
}

在上述示例中,當(dāng) myObject.prop 的值發(fā)生變化時(shí),watch 中的處理函數(shù)會(huì)被調(diào)用。

使用 computed

computed 是 Vue 提供的一個(gè)計(jì)算屬性,用于監(jiān)聽(tīng)對(duì)象或數(shù)組某個(gè)屬性的變化。當(dāng)被監(jiān)聽(tīng)的屬性發(fā)生變化時(shí),computed 屬性會(huì)自動(dòng)更新。下面是一個(gè)示例代碼:

data() {
  return {
    myArray: [1, 2, 3]
  };
},
computed: {
  arraySum() {
    return this.myArray.reduce((acc, cur) => acc + cur, 0);
  }
}

在上述示例中,arraySum 是一個(gè)計(jì)算屬性,它監(jiān)聽(tīng) myArray 數(shù)組的變化,并計(jì)算數(shù)組的和。當(dāng) myArray 數(shù)組發(fā)生變化時(shí),arraySum 屬性會(huì)自動(dòng)更新。

需要注意的是,對(duì)于數(shù)組的變化,Vue 還提供了一些特殊的方法,比如 Vue.set 或者使用擴(kuò)展運(yùn)算符 ... 來(lái)觸發(fā)響應(yīng)式更新。在項(xiàng)目中,如果需要監(jiān)聽(tīng)對(duì)象或數(shù)組某個(gè)屬性的變化,可以選擇使用 watch 或者 computed,根據(jù)具體需求選擇合適的方式。需要注意的是,當(dāng)監(jiān)聽(tīng)對(duì)象或數(shù)組某個(gè)屬性的變化時(shí),要確保這個(gè)屬性是響應(yīng)式的,否則監(jiān)聽(tīng)不到變化。

解決方式

  • 使用 this.$set() 方法:
    this.$set() 是 Vue 提供的一個(gè)方法,用于設(shè)置對(duì)象或者數(shù)組某個(gè)屬性的值。當(dāng)使用 this.$set() 方法設(shè)置對(duì)象或數(shù)組某個(gè)屬性的值時(shí),Vue 會(huì)自動(dòng)將這個(gè)屬性變?yōu)轫憫?yīng)式的,從而能夠監(jiān)聽(tīng)到這個(gè)屬性的變化。下面是一個(gè)示例代碼:

    this.$set(this.myArray, 0, 'new value'); // 設(shè)置數(shù)組某一項(xiàng)的值
    this.$set(this.myObject, 'prop', 'new value'); // 設(shè)置對(duì)象某個(gè)屬性的值
    
  • 使用以下幾個(gè)數(shù)組的方法:
    Vue 源碼里緩存了數(shù)組的原型鏈,然后重寫(xiě)了以下幾個(gè)方法,觸發(fā)這幾個(gè)方法的時(shí)候會(huì) observer 數(shù)據(jù),意思是使用這些方法不用再進(jìn)行額外的操作,視圖自動(dòng)進(jìn)行更新。推薦使用 splice() 方法,因?yàn)?nbsp;splice() 可以在數(shù)組的任何位置進(jìn)行刪除/添加操作。

    this.myArray.splice(0, 1, 'new value'); // 使用 splice() 方法設(shè)置數(shù)組某一項(xiàng)的值
    

需要注意的是,在監(jiān)聽(tīng)對(duì)象或數(shù)組某個(gè)屬性的變化時(shí),要確保這個(gè)屬性是響應(yīng)式的,否則監(jiān)聽(tīng)不到變化。如果需要監(jiān)聽(tīng)對(duì)象或數(shù)組某個(gè)屬性的變化,可以選擇使用 watch 或者 computed,根據(jù)具體需求選擇合適的方式。

vm.$set() 方法

vm.$set() 是 Vue 提供的一個(gè)方法,用于設(shè)置對(duì)象或數(shù)組某個(gè)屬性的值。當(dāng)使用 vm.$set() 方法設(shè)置對(duì)象或數(shù)組某個(gè)屬性的值時(shí),Vue 會(huì)自動(dòng)將這個(gè)屬性變?yōu)轫憫?yīng)式的,從而能夠監(jiān)聽(tīng)到這個(gè)屬性的變化。

vm.$set() 的實(shí)現(xiàn)原理是:

  • 如果目標(biāo)是數(shù)組,直接使用數(shù)組的 splice() 方法觸發(fā)響應(yīng)式;
  • 如果目標(biāo)是對(duì)象,會(huì)先判斷屬性是否存在、對(duì)象是否是響應(yīng)式,最終如果要對(duì)屬性進(jìn)行響應(yīng)式處理,則是通過(guò)調(diào)用 defineReactive 方法進(jìn)行響應(yīng)式處理。defineReactive 方法就是 Vue 在初始化對(duì)象時(shí),給對(duì)象屬性采用 Object.defineProperty 動(dòng)態(tài)添加 getter 和 setter 的功能所調(diào)用的方法。

總之,vm.$set() 方法的實(shí)現(xiàn)原理是通過(guò)修改對(duì)象或數(shù)組的屬性值,從而觸發(fā) Vue 的響應(yīng)式機(jī)制,使得 Vue 能夠監(jiān)聽(tīng)到屬性的變化,并及時(shí)更新視圖。需要注意的是,在使用 vm.$set() 方法時(shí),要確保對(duì)象或數(shù)組是響應(yīng)式的,否則無(wú)法觸發(fā)響應(yīng)式機(jī)制。

持續(xù)學(xué)習(xí)總結(jié)記錄中,回顧一下上面的內(nèi)容:
在 Vue 中,你可以使用 watch 或 computed 來(lái)監(jiān)聽(tīng)對(duì)象或數(shù)組某個(gè)屬性的變化。如果直接設(shè)置數(shù)組的某一項(xiàng)的值或者對(duì)象的某個(gè)屬性值,頁(yè)面不會(huì)更新。解決方式有兩個(gè):使用 this.$set() 方法或者使用以下幾個(gè)數(shù)組的方法:splice()、push()、pop()、shift()unshift()、sort()、reverse()。需要注意的是,要確保對(duì)象或數(shù)組是響應(yīng)式的,否則無(wú)法觸發(fā)響應(yīng)式機(jī)制。

總結(jié) 

到此這篇關(guān)于前端vue如何監(jiān)聽(tīng)對(duì)象或者數(shù)組某個(gè)屬性變化的文章就介紹到這了,更多相關(guān)vue監(jiān)聽(tīng)對(duì)象或者數(shù)組屬性變化內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 60個(gè)vue常用工具類(lèi)

    60個(gè)vue常用工具類(lèi)

    這篇文章主要介紹了60個(gè)vue常用工具類(lèi),包括vue郵箱驗(yàn)證,vue瀏覽器識(shí)別,vue操作系統(tǒng)識(shí)別,vue html過(guò)濾,vue身份證校驗(yàn)等需要的朋友可以參考下
    2023-01-01
  • 關(guān)于el-form表單驗(yàn)證中的validator與validate使用時(shí)的問(wèn)題

    關(guān)于el-form表單驗(yàn)證中的validator與validate使用時(shí)的問(wèn)題

    這篇文章主要介紹了關(guān)于el-form表單驗(yàn)證中的validator與validate使用時(shí)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • 一步步講解Vue如何啟動(dòng)項(xiàng)目

    一步步講解Vue如何啟動(dòng)項(xiàng)目

    這篇文章主要給大家介紹了關(guān)于Vue如何啟動(dòng)項(xiàng)目的相關(guān)資料,還介紹了解決vue啟動(dòng)項(xiàng)目時(shí)間很長(zhǎng)問(wèn)題的相關(guān)方法,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02
  • vue插件draggable實(shí)現(xiàn)拖拽移動(dòng)圖片順序

    vue插件draggable實(shí)現(xiàn)拖拽移動(dòng)圖片順序

    這篇文章主要為大家詳細(xì)介紹了vue插件draggable實(shí)現(xiàn)拖拽移動(dòng)圖片順序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • Vue 項(xiàng)目分環(huán)境打包的方法示例

    Vue 項(xiàng)目分環(huán)境打包的方法示例

    這篇文章主要介紹了Vue 項(xiàng)目分環(huán)境打包的方法示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • Vue3項(xiàng)目頁(yè)面實(shí)現(xiàn)echarts圖表漸變色的動(dòng)態(tài)配置的實(shí)現(xiàn)步驟

    Vue3項(xiàng)目頁(yè)面實(shí)現(xiàn)echarts圖表漸變色的動(dòng)態(tài)配置的實(shí)現(xiàn)步驟

    在開(kāi)發(fā)可配置業(yè)務(wù)平臺(tái)時(shí),需要實(shí)現(xiàn)讓用戶對(duì)項(xiàng)目?jī)?nèi)echarts圖表的動(dòng)態(tài)配置,讓用戶脫離代碼也能實(shí)現(xiàn)簡(jiǎn)單的圖表樣式配置,顏色作為圖表樣式的重要組成部分,其配置方式是項(xiàng)目要解決的重點(diǎn)問(wèn)題,所以本文介紹了Vue3項(xiàng)目頁(yè)面實(shí)現(xiàn)echarts圖表漸變色的動(dòng)態(tài)配置
    2024-10-10
  • vue響應(yīng)式系統(tǒng)之observe、watcher、dep的源碼解析

    vue響應(yīng)式系統(tǒng)之observe、watcher、dep的源碼解析

    這篇文章主要介紹了vue響應(yīng)式系統(tǒng)之observe、watcher、dep的源碼解析,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-04-04
  • 基于vue+h5實(shí)現(xiàn)車(chē)牌號(hào)輸入框功能(demo)

    基于vue+h5實(shí)現(xiàn)車(chē)牌號(hào)輸入框功能(demo)

    最近開(kāi)發(fā)項(xiàng)目是學(xué)校校內(nèi)車(chē)輛超速方面的統(tǒng)計(jì)檢測(cè)方面的系統(tǒng),在開(kāi)發(fā)過(guò)程中發(fā)現(xiàn)有個(gè)小功能,就是用戶移動(dòng)端添加車(chē)牌號(hào),剛開(kāi)始想著輸入框,提交時(shí)正則效驗(yàn)一下格式,最后感覺(jué)不方便,所以就簡(jiǎn)單自己手寫(xiě)了一個(gè)H5車(chē)牌號(hào)軟鍵盤(pán),對(duì)vue車(chē)牌號(hào)輸入框?qū)崿F(xiàn)代碼感興趣的朋友一起看看吧
    2025-03-03
  • vue基于element的區(qū)間選擇組件

    vue基于element的區(qū)間選擇組件

    這篇文章主要介紹了vue基于element的區(qū)間選擇組件,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • Vue.js@2.6.10更新內(nèi)置錯(cuò)誤處機(jī)制Fundebug同步支持相應(yīng)錯(cuò)誤監(jiān)控

    Vue.js@2.6.10更新內(nèi)置錯(cuò)誤處機(jī)制Fundebug同步支持相應(yīng)錯(cuò)誤監(jiān)控

    這篇文章主要介紹了Vue.js@2.6.10更新內(nèi)置錯(cuò)誤處機(jī)制,F(xiàn)undebug同步支持相應(yīng)錯(cuò)誤監(jiān)控 ,需要的朋友可以參考下
    2019-05-05

最新評(píng)論