Vue 響應(yīng)式原理 3-3

概念

結(jié)論:
Vue 在更新 DOM 時(shí)是異步執(zhí)行的

流程:
1.只要偵聽(tīng)到數(shù)據(jù)變化挎扰,Vue 將開(kāi)啟一個(gè)隊(duì)列夹界,并緩沖在同一事件循環(huán)中發(fā)生的所有數(shù)據(jù)變更
2.如果同一個(gè) watcher 被多次觸發(fā)显晶,只會(huì)被推入到隊(duì)列中一次振惰。
性能優(yōu)化,這種在緩沖時(shí)去除重復(fù)數(shù)據(jù)對(duì)于避免不必要的計(jì)算和 DOM 操作是非常重要的
3.在下一個(gè)的事件循環(huán)“tick”中,Vue 刷新隊(duì)列并執(zhí)行實(shí)際 (已去重的) 工作。

異步事件更新2

(↑ 自己理解的數(shù)據(jù)更新意思)

Vue 在內(nèi)部對(duì)異步隊(duì)列嘗試使用原生的 Promise.then、MutationObserver 和 setImmediate稠腊,
如果執(zhí)行環(huán)境不支持,則會(huì)采用 setTimeout(fn, 0) 代替鸣哀。

異步隊(duì)列操作的語(yǔ)法

MutationObserver
setImmediate


語(yǔ)法解釋
在工作中意義何在架忌? 【獲取更新后的 DOM 狀態(tài)】

多數(shù)情況我們不需要關(guān)心這個(gè)過(guò)程,但是如果你想基于更新后的 DOM 狀態(tài)來(lái)做點(diǎn)什么我衬,這就可能會(huì)有些棘手叹放。
雖然 Vue.js 通常鼓勵(lì)開(kāi)發(fā)人員使用“數(shù)據(jù)驅(qū)動(dòng)”的方式思考,避免直接接觸 DOM挠羔,但是有時(shí)我們必須要這么做井仰。

通過(guò)Vue全局方法和實(shí)例方法,我們可以獲取到更新后的時(shí)間節(jié)點(diǎn)
入口函數(shù)中破加,可以使用全局方法:Vue.nextTick(fn)
單頁(yè)面組件中俱恶,可以使用實(shí)例方法:vm.$nextTick()

官方例:
全局方法

<div id="example">{{message}}</div>

var vm = new Vue({
  el: '#example',
  data: {
    message: '123'
  }
})
vm.message = 'new message' // 更改數(shù)據(jù)
vm.$el.textContent === 'new message' // false
Vue.nextTick(function () {
  vm.$el.textContent === 'new message' // true
})

實(shí)例方法

<div id="example">{{message}}</div>

Vue.component('example', {
  template: '<span>{{ message }}</span>',
  data: function () {
    return {
      message: '未更新'
    }
  },
  methods: {
    updateMessage: function () {
      this.message = '已更新'
      console.log(this.$el.textContent) // => '未更新'
      this.$nextTick(function () {
        console.log(this.$el.textContent) // => '已更新'
      })
    }
  }
})
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市范舀,隨后出現(xiàn)的幾起案子合是,更是在濱河造成了極大的恐慌,老刑警劉巖锭环,帶你破解...
    沈念sama閱讀 217,084評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件聪全,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡田藐,警方通過(guò)查閱死者的電腦和手機(jī)荔烧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,623評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)汽久,“玉大人,你說(shuō)我怎么就攤上這事踊餐【按迹” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,450評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵吝岭,是天一觀的道長(zhǎng)三痰。 經(jīng)常有香客問(wèn)我吧寺,道長(zhǎng),這世上最難降的妖魔是什么散劫? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,322評(píng)論 1 293
  • 正文 為了忘掉前任稚机,我火速辦了婚禮,結(jié)果婚禮上获搏,老公的妹妹穿的比我還像新娘赖条。我一直安慰自己,他們只是感情好常熙,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,370評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布纬乍。 她就那樣靜靜地躺著,像睡著了一般裸卫。 火紅的嫁衣襯著肌膚如雪仿贬。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,274評(píng)論 1 300
  • 那天墓贿,我揣著相機(jī)與錄音茧泪,去河邊找鬼。 笑死聋袋,一個(gè)胖子當(dāng)著我的面吹牛调炬,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播舱馅,決...
    沈念sama閱讀 40,126評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼缰泡,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了代嗤?” 一聲冷哼從身側(cè)響起棘钞,我...
    開(kāi)封第一講書(shū)人閱讀 38,980評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎干毅,沒(méi)想到半個(gè)月后宜猜,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,414評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡硝逢,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,599評(píng)論 3 334
  • 正文 我和宋清朗相戀三年姨拥,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片渠鸽。...
    茶點(diǎn)故事閱讀 39,773評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡叫乌,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出徽缚,到底是詐尸還是另有隱情憨奸,我是刑警寧澤,帶...
    沈念sama閱讀 35,470評(píng)論 5 344
  • 正文 年R本政府宣布凿试,位于F島的核電站排宰,受9級(jí)特大地震影響似芝,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜板甘,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,080評(píng)論 3 327
  • 文/蒙蒙 一党瓮、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧盐类,春花似錦寞奸、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,713評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至硬毕,卻和暖如春呻引,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背吐咳。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,852評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工逻悠, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人韭脊。 一個(gè)月前我還...
    沈念sama閱讀 47,865評(píng)論 2 370
  • 正文 我出身青樓童谒,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親沪羔。 傳聞我的和親對(duì)象是個(gè)殘疾皇子饥伊,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,689評(píng)論 2 354

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

  • 現(xiàn)在是時(shí)候深入一下了!Vue 最獨(dú)特的特性之一蔫饰,是其非侵入性的響應(yīng)式系統(tǒng)琅豆。數(shù)據(jù)模型僅僅是普通的 JavaScrip...
    youins閱讀 686評(píng)論 0 3
  • 前言 Vue.js 的核心包括一套“響應(yīng)式系統(tǒng)”。 “響應(yīng)式”篓吁,是指當(dāng)數(shù)據(jù)改變后茫因,Vue 會(huì)通知到使用該數(shù)據(jù)的代碼...
    NARUTO_86閱讀 37,490評(píng)論 8 86
  • 如何追蹤變化? 把一個(gè)js對(duì)象傳遞給Vue實(shí)例的data選項(xiàng)杖剪,Vue將遍歷此對(duì)象的所有屬性冻押,并通過(guò) Object...
    hello_water閱讀 1,111評(píng)論 0 4
  • ??Vue很好用的一點(diǎn)是響應(yīng)式系統(tǒng)(reactivity system)。模型層(model)只是普通JS對(duì)象盛嘿,修...
    小小的開(kāi)發(fā)人員閱讀 2,532評(píng)論 0 12
  • 前言 Vue.js 的核心包括一套“響應(yīng)式系統(tǒng)”孩擂。 “響應(yīng)式”狼渊,是指當(dāng)數(shù)據(jù)改變后,Vue 會(huì)通知到使用該數(shù)據(jù)的代碼...
    world_7735閱讀 950評(píng)論 0 2