vue中的小坑

  1. 數(shù)據(jù)綁定的問(wèn)題捌浩。
    看官方文檔的時(shí)候,發(fā)現(xiàn)一個(gè)疑問(wèn)工秩,當(dāng)我們異步操作改變一個(gè)根級(jí)別的data 的時(shí)候尸饺,我們經(jīng)常異步操作,然后拿到結(jié)果助币,直接賦值給這個(gè)對(duì)象浪听,那么問(wèn)題來(lái)了,這時(shí)候眉菱,這個(gè)對(duì)象是不是響應(yīng)式的呢迹栓,,
    答案是肯定的俭缓。
test

操作的結(jié)果見(jiàn)下圖

測(cè)試結(jié)果

為什么是這樣克伊,,而且和官方 推薦的操作方式不一樣华坦,第一個(gè)setTimeout也能成功呢愿吹。

this.project = Object.assign({},this.project,obj)

的方法明明不一樣,為什么第一個(gè)setTimeout可以變成響應(yīng)式的呢惜姐?

個(gè)人理解:

  • 官方推薦的做法犁跪,只是深拷貝了這個(gè)隊(duì)象,最終結(jié)果是 讓這個(gè)對(duì)象等于一個(gè)新的對(duì)象歹袁,和我們直接賦值是一樣的坷衍。所以,条舔,這個(gè)時(shí)候枫耳。project是響應(yīng)式的,我們不用考慮去閱讀源碼就可以得到的推測(cè)( vue 官方并沒(méi)有說(shuō)改寫了Object.assgin()方法)

  • 但是對(duì)于第二個(gè)setTimeout逞刷, 因?yàn)樽铋_(kāi)始我們?cè)谧铋_(kāi)始 vue的 init階段嘉涌,并不能給這個(gè)數(shù)據(jù)綁定set和get 的方法,最終夸浅,vue也不能變成響應(yīng)式的仑最,所以,即使帆喇,我們能在控制臺(tái)答應(yīng)出來(lái) list.a = ‘xxxxx' VUE的視圖層也不能響應(yīng)警医。

解決辦法:

方法三

這三種方法,都行坯钦。

另外還有一個(gè)比較容易 迷茫的地方:

test1
test1
result

為什么這里會(huì)渲染呢预皇,這個(gè)時(shí)候,難道 lala.text,是響應(yīng)式的么婉刀。答案是不是的吟温,如果我們代碼寫成這樣,

test2

結(jié)果不能正常渲染 la.text 突颊。鲁豪。
為什么會(huì)是這樣的,我們要注意到律秃, VUE中DOM操作是一個(gè)異步的操作爬橡,會(huì)有一個(gè)延遲在的。
大致流程是這樣的棒动。

  • this.la = {}, 會(huì)觸發(fā)setter,
  • setter 通知相關(guān)指令進(jìn)行數(shù)據(jù)更新糙申,
  • 然后 this.la['text'] = 'text'
  • 指令開(kāi)始執(zhí)行。這個(gè)時(shí)候去訪問(wèn) this.la , la.text 已經(jīng)存在了船惨。

由此柜裸,我們來(lái)看一下第二種, 因?yàn)橹朗瑃his.la['text'] = 'text' 不能觸發(fā) setter 粘室,他不是響應(yīng)式的,所以卜范,即使我們?nèi)匀荒躢onsole.log ,但是衔统,不是響應(yīng)式的,根本不能觸發(fā) setter海雪, 就談不上更新了锦爵。

2 .對(duì) 生命周期的再次回顧 (比較重要的地方)

生命周期

這個(gè)應(yīng)該是一個(gè)比較完整的生命周期的圖示。
之前有點(diǎn)理解偏差.

  • 當(dāng)我們需要得到數(shù)據(jù)之后奥裸,要操作一波DOM的時(shí)候险掀,我們可以放在updated中去做,這時(shí)候就是當(dāng)數(shù)據(jù)更新完成湾宙,組件也更新DOM了樟氢。冈绊。。但是好像官方不推薦使用updated埠啃,推薦使用 nextTick 去做死宣。
reson
  1. 看vue 源碼分析 之類的文章,得到的一些收獲
源碼

之所以碴开,vue能做到響應(yīng)式毅该,基本上是因?yàn)?initState做的事情。潦牛。

init做的事
Obseve做的事
defineReactive
依賴收集
總結(jié)依賴收集
總結(jié)

文章參考:
vue源碼分析
關(guān)于VUE實(shí)例的生命周期

最后編輯于
?著作權(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)店門蚣常,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人痊银,你說(shuō)我怎么就攤上這事抵蚊。” “怎么了溯革?”我有些...
    開(kāi)封第一講書人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵贞绳,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我致稀,道長(zhǎng)冈闭,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任抖单,我火速辦了婚禮萎攒,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘矛绘。我一直安慰自己耍休,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布货矮。 她就那樣靜靜地躺著羊精,像睡著了一般。 火紅的嫁衣襯著肌膚如雪囚玫。 梳的紋絲不亂的頭發(fā)上喧锦,一...
    開(kāi)封第一講書人閱讀 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)封第一講書人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤趁舀,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后祝沸,有當(dāng)?shù)厝嗽跇淞掷锇l(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)封第一講書人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至扁掸,卻和暖如春翘县,著一層夾襖步出監(jiān)牢的瞬間最域,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 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)容

  • 這篇筆記主要包含 Vue 2 不同于 Vue 1 或者特有的內(nèi)容翘魄,還有我對(duì)于 Vue 1.0 印象不深的內(nèi)容。關(guān)于...
    云之外閱讀 5,045評(píng)論 0 29
  • 1.安裝 可以簡(jiǎn)單地在頁(yè)面引入Vue.js作為獨(dú)立版本舀奶,Vue即被注冊(cè)為全局變量暑竟,可以在頁(yè)面使用了。 如果希望搭建...
    Awey閱讀 10,995評(píng)論 4 129
  • 轉(zhuǎn)載 :OpenDiggawesome-github-vue 是由OpenDigg整理并維護(hù)的Vue相關(guān)開(kāi)源項(xiàng)目庫(kù)...
    果汁密碼閱讀 23,092評(píng)論 8 124
  • 第四場(chǎng)開(kāi)打之前育勺,所有人都明白讓勇士3:1回到奧克蘭對(duì)騎士意味著什么但荤! 所以第一節(jié)我們就看到了詹姆斯那次兇狠的前場(chǎng)斷...
    王濤濤老師閱讀 531評(píng)論 0 1
  • 1. Python開(kāi)發(fā)環(huán)境 Mac OS 安裝Python: todo 運(yùn)行Python 2.x版本:python...
    sylcrq閱讀 277評(píng)論 0 0