vue 數(shù)組更新視圖不更新

眾所周知,Vue.js3.0之前是使用了Object.defineProperty來(lái)實(shí)現(xiàn)雙向數(shù)據(jù)綁定。當(dāng)數(shù)據(jù)變化時(shí)瘟芝,會(huì)反應(yīng)到視圖上。但是是有缺陷的褥琐,比如以下情況:

this.arr[1] = 11
this.arr.length = 2

對(duì)數(shù)組的這兩種操作可以改變this.arr锌俱,但是視圖不會(huì)更新。
去搜索敌呈,文章總是一句話(huà)概況:由于js的限制贸宏,Vue無(wú)法檢測(cè)數(shù)組某些變動(dòng)。
暈死磕洪,還是自己動(dòng)手吧?粤贰!析显!

Object.defineProperty

回到原生js鲫咽,我們?cè)囍肙bject.defineProperty來(lái)改寫(xiě)數(shù)據(jù):

var data = {}
Object.defineProperty(data, 'test', {
  set (value) {
    this.testValue = value
    console.log('更新')
  },
  get () {
      return this.testValue
  }
})

data.test = [1, 2, 3]       // 打印‘更新’
console.log(data.test)      // [1, 2, 3]
data.test[3] = 4            // 沒(méi)打印 ‘更新’
console.log(data.test)      // [1, 2, 3, 4] 

使用array[index]賦值的方式無(wú)法觸發(fā)setter,自然無(wú)法觸發(fā)視圖更新(Vue中,數(shù)據(jù)變動(dòng)分尸,setter調(diào)用notify去更新視圖)锦聊。

Proxy

換一種方式,使用Vue3.0所使用的Proxy代理試試:

var obj = {
  test: '',
}

let objProxy = new Proxy(obj, {
   get: (target, prop) => {
     return prop in target ? target[prop] : '空'
   },
   set: (target, prop, value) => {
     target[prop] = value
     console.log('更新')
   }
})

objProxy.test = [1, [2, 3], 4]     // 打印‘更新’
console.log(obj.test)              // [1, [2, 3], 4]
objProxy.test[1][1] = 5            // 沒(méi)打印 ‘更新’
console.log(obj.test)              // [1, [2, 5], 4]

結(jié)果顯示箩绍,同樣無(wú)法打印更新孔庭,也就無(wú)法觸發(fā)視圖更新。
好吧伶选,這就是js的限制史飞。

解決

變異方法(Vue中做了變動(dòng),可以觸發(fā)視圖更新):
push()仰税、pop()构资、shift()、unshift()陨簇、splice()吐绵、sort()
對(duì)于修改數(shù)組的某個(gè)元素的值,可以利用Vue提供的方法:

this.$set(data of array, index of array, newValue)
// 例如:
this.$set(this.arr, 1, 4)

還可以使用變異方法中的splice來(lái)替換:

data of array.splice(要插入的位置, 要?jiǎng)h除的項(xiàng)數(shù), 要插入的值)
// 例如:
this.arr.splice(1, 1, 4)

this.array.length = x 也可以使用splice來(lái)操作:

this.arr.splice(2)

這樣河绽,arr就只剩前面兩項(xiàng)己单。

ps:不對(duì)之處,敬請(qǐng)指正0沂巍N屏!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末苟跪,一起剝皮案震驚了整個(gè)濱河市廷痘,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌件已,老刑警劉巖笋额,帶你破解...
    沈念sama閱讀 206,311評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異篷扩,居然都是意外死亡兄猩,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)鉴未,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)枢冤,“玉大人,你說(shuō)我怎么就攤上這事铜秆⊙驼妫” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵羽峰,是天一觀(guān)的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng)梅屉,這世上最難降的妖魔是什么值纱? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮坯汤,結(jié)果婚禮上虐唠,老公的妹妹穿的比我還像新娘。我一直安慰自己惰聂,他們只是感情好疆偿,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著搓幌,像睡著了一般杆故。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上溉愁,一...
    開(kāi)封第一講書(shū)人閱讀 49,031評(píng)論 1 285
  • 那天处铛,我揣著相機(jī)與錄音,去河邊找鬼拐揭。 笑死撤蟆,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的堂污。 我是一名探鬼主播家肯,決...
    沈念sama閱讀 38,340評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼盟猖!你這毒婦竟也來(lái)了讨衣?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤扒披,失蹤者是張志新(化名)和其女友劉穎值依,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體碟案,經(jīng)...
    沈念sama閱讀 43,466評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡愿险,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了价说。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片辆亏。...
    茶點(diǎn)故事閱讀 38,039評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖鳖目,靈堂內(nèi)的尸體忽然破棺而出扮叨,到底是詐尸還是另有隱情,我是刑警寧澤领迈,帶...
    沈念sama閱讀 33,701評(píng)論 4 323
  • 正文 年R本政府宣布彻磁,位于F島的核電站碍沐,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏衷蜓。R本人自食惡果不足惜累提,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望磁浇。 院中可真熱鬧斋陪,春花似錦、人聲如沸置吓。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)衍锚。三九已至友题,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間构拳,已是汗流浹背咆爽。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留置森,地道東北人斗埂。 一個(gè)月前我還...
    沈念sama閱讀 45,497評(píng)論 2 354
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像凫海,于是被迫代替她去往敵國(guó)和親呛凶。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • 0. 解決方案 1.當(dāng)你利用索引直接設(shè)置一個(gè)項(xiàng)時(shí)行贪,例如:vm.items[indexOfItem] = newVa...
    安石0閱讀 5,509評(píng)論 0 0
  • VUE介紹 Vue的特點(diǎn)構(gòu)建用戶(hù)界面漾稀,只關(guān)注View層簡(jiǎn)單易學(xué),簡(jiǎn)潔建瘫、輕量崭捍、快速漸進(jìn)式框架 框架VS庫(kù)庫(kù),是一封裝...
    多多醬_DuoDuo_閱讀 2,687評(píng)論 1 17
  • 面試官: 實(shí)現(xiàn)雙向綁定Proxy比defineproperty優(yōu)劣如何? 面試官系列(4): 實(shí)現(xiàn)雙向綁定Prox...
    流動(dòng)碼文閱讀 23,004評(píng)論 6 77
  • 什么叫庫(kù)啰脚? 代表是jQuery ? 庫(kù)本質(zhì)是就是一些函數(shù)的集合殷蛇,就是將一些函數(shù)放到一個(gè)獨(dú)立的js文件中 ? ...
    cj_jax閱讀 837評(píng)論 0 1
  • 一:什么是閉包?閉包的用處橄浓? (1)閉包就是能夠讀取其他函數(shù)內(nèi)部變量的函數(shù)粒梦。在本質(zhì)上,閉包就 是將函數(shù)內(nèi)部和函數(shù)外...
    xuguibin閱讀 9,523評(píng)論 1 52