$nextTick和$forceUpdate

vm.$nextTick( [callback] )

官方解釋: 將回調(diào)延遲到下次 DOM 更新循環(huán)之后執(zhí)行

要理解這句話羽圃,首先要了解一下vue的異步更新隊(duì)列灿渴,Vue 異步執(zhí)行 DOM 更新探越。只要觀察到數(shù)據(jù)變化雷客,不會立即更新DOM,Vue 將開啟一個(gè)隊(duì)列,并緩沖在同一事件循環(huán)中發(fā)生的所有數(shù)據(jù)改變牍氛。如果同一個(gè) 數(shù)據(jù)被的多次 改變猜敢,只會被推入到隊(duì)列中一次。例如耐量,當(dāng)你設(shè)置 vm.someData = 'new value' 飞蚓,對應(yīng)的DOM更新會被推到一個(gè)隊(duì)列里,該組件不會立即重新渲染廊蜒,會在當(dāng)前tick完畢后趴拧,在下一個(gè)tick中渲染DOM。在事件循環(huán)中山叮,每進(jìn)行一次循環(huán)操作稱為tick著榴。而nextTick函數(shù)就是vue提供的一個(gè)實(shí)例方法,數(shù)據(jù)更新后等待下一個(gè)tick里Dom更新完后執(zhí)行回調(diào)屁倔,回調(diào)的 this 自動綁定到調(diào)用它的實(shí)例上脑又。
例如:

html: 
<span class="test">{{egData}}</span>
<el-button @click="changeData">改變</el-button>

js:
new Vue({
    data () {
        return {
            egData: 'old Message'
        }
    }
    methods: {
        changeData () {
          this.egData = 'new Message'
          console.log($('.test').html(), '-----------------------')
        }
    }
})

結(jié)果: 第一次點(diǎn)擊輸出 old Message -----------------------,第二次點(diǎn)擊輸出 new Message -----------------------

使用$nextTick:

js:
new Vue({
    data () {
        return {
            egData: 'old Message'
        }
    }
    methods: {
        changeData () {
          this.egData = 'new Message'
          this.$nextTick(function () {
            console.log($('.test').html(), '-----------------------')
          })
          
        }
    }
})

結(jié)果:不管第幾次點(diǎn)擊,都輸出 new Message -----------------------

$nextTick使用場景:

**1问麸、數(shù)據(jù)更新后想要馬上操作新的DOM往衷,需要把操作寫在nextTick的回調(diào)里
2、在created鉤子函數(shù)里需要操作DOM严卖,也可以把操作寫在nextTick的回調(diào)里,(created鉤子函數(shù)里還沒有掛載dom席舍,所以直接操作會有問題)

$forceUpdate()

迫使Vue實(shí)例重新(rander)渲染虛擬DOM,注意并不是重新加載組件哮笆。結(jié)合vue的生命周期来颤,調(diào)用$forceUpdate后只會觸發(fā)beforeUpdate和updated這兩個(gè)鉤子函數(shù),不會觸發(fā)其他的鉤子函數(shù)稠肘。它僅僅影響實(shí)例本身和插入插槽內(nèi)容的子組件福铅,而不是所有子組件。

$forceUpdate()使用場景:

1项阴、當(dāng)在data里沒有顯示的聲明一個(gè)對象的屬性滑黔,而是之后給該對象添加屬性,這種情況vue是檢測不到數(shù)據(jù)變化的鲁冯,可以使用$forceUpdate()**

html:

<span class="test">{{egData.value}}</span>
<el-button @click="changeData">改變</el-button>

js:
egData: {}

...


changeData () {
    this.egData.value = 'oldValue'
    this.$forceUpdate()  // dom會更新
}

但是這種做法并不推薦拷沸,官方說如果你現(xiàn)在的場景需要用forceUpdate方法 ,那么99%是你的操作有問題,如上data里不顯示聲明對象的屬性薯演,之后添加屬性時(shí)正確的做法時(shí)用 vm.$set() 方法撞芍,所以forceUpdate請慎用

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市跨扮,隨后出現(xiàn)的幾起案子序无,更是在濱河造成了極大的恐慌,老刑警劉巖衡创,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件帝嗡,死亡現(xiàn)場離奇詭異,居然都是意外死亡璃氢,警方通過查閱死者的電腦和手機(jī)哟玷,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來一也,“玉大人巢寡,你說我怎么就攤上這事∫叮” “怎么了抑月?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長舆蝴。 經(jīng)常有香客問我谦絮,道長题诵,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任层皱,我火速辦了婚禮性锭,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘奶甘。我一直安慰自己篷店,他們只是感情好祭椰,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布臭家。 她就那樣靜靜地躺著,像睡著了一般方淤。 火紅的嫁衣襯著肌膚如雪钉赁。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天携茂,我揣著相機(jī)與錄音你踩,去河邊找鬼。 笑死讳苦,一個(gè)胖子當(dāng)著我的面吹牛带膜,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播鸳谜,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼膝藕,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了咐扭?” 一聲冷哼從身側(cè)響起芭挽,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎蝗肪,沒想到半個(gè)月后袜爪,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡薛闪,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年辛馆,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片豁延。...
    茶點(diǎn)故事閱讀 39,690評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡昙篙,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出术浪,到底是詐尸還是另有隱情瓢对,我是刑警寧澤,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布胰苏,位于F島的核電站硕蛹,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜法焰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一秧荆、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧埃仪,春花似錦乙濒、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至傻丝,卻和暖如春甘有,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背葡缰。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工亏掀, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人泛释。 一個(gè)月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓滤愕,卻偏偏與公主長得像,于是被迫代替她去往敵國和親怜校。 傳聞我的和親對象是個(gè)殘疾皇子间影,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評論 2 353

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