$nextTick和$forceUpdate

$nextTick和$forceUpdate

vm.$nextTick( [callback] )

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

要理解這句話壹瘟,首先要了解一下vue的異步更新隊(duì)列憔鬼,Vue 異步執(zhí)行 DOM 更新。只要觀察到數(shù)據(jù)變化站蝠,不會(huì)立即更新DOM,Vue 將開(kāi)啟一個(gè)隊(duì)列热凹,并緩沖在同一事件循環(huán)中發(fā)生的所有數(shù)據(jù)改變项棠。如果同一個(gè) 數(shù)據(jù)被的多次 改變几苍,只會(huì)被推入到隊(duì)列中一次。例如智厌,當(dāng)你設(shè)置 vm.someData = 'new value' 诲泌,對(duì)應(yīng)的DOM更新會(huì)被推到一個(gè)隊(duì)列里,該組件不會(huì)立即重新渲染铣鹏,會(huì)在當(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 自動(dòng)綁定到調(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(), '-----------------------')
        }
    }
})
復(fù)制代碼

結(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(), '-----------------------')
          })

        }
    }
})
復(fù)制代碼

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

$nextTick使用場(chǎng)景:

1栅受、數(shù)據(jù)更新后想要馬上操作新的DOM,需要把操作寫(xiě)在nextTick的回調(diào)里

2恭朗、在created鉤子函數(shù)里需要操作DOM屏镊,也可以把操作寫(xiě)在nextTick的回調(diào)里,(created鉤子函數(shù)里還沒(méi)有掛載dom,所以直接操作會(huì)有問(wèn)題)

$forceUpdate()

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

$forceUpdate()使用場(chǎng)景:

1歌逢、當(dāng)在data里沒(méi)有顯示的聲明一個(gè)對(duì)象的屬性,而是之后給該對(duì)象添加屬性翘狱,這種情況vue是檢測(cè)不到數(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會(huì)更新
}

復(fù)制代碼

但是這種做法并不推薦,官方說(shuō)如果你現(xiàn)在的場(chǎng)景需要用forceUpdate方法 ,那么99%是你的操作有問(wèn)題,如上data里不顯示聲明對(duì)象的屬性阱高,之后添加屬性時(shí)正確的做法時(shí)用 vm.$set() 方法赚导,所以forceUpdate請(qǐng)慎用
轉(zhuǎn)自https://juejin.cn/post/6844903812872798216

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市赤惊,隨后出現(xiàn)的幾起案子吼旧,更是在濱河造成了極大的恐慌,老刑警劉巖荐捻,帶你破解...
    沈念sama閱讀 218,941評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件黍少,死亡現(xiàn)場(chǎng)離奇詭異寡夹,居然都是意外死亡处面,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)菩掏,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)魂角,“玉大人,你說(shuō)我怎么就攤上這事智绸∫熬荆” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,345評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵瞧栗,是天一觀的道長(zhǎng)斯稳。 經(jīng)常有香客問(wèn)我,道長(zhǎng)迹恐,這世上最難降的妖魔是什么挣惰? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,851評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮殴边,結(jié)果婚禮上憎茂,老公的妹妹穿的比我還像新娘。我一直安慰自己锤岸,他們只是感情好竖幔,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,868評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著是偷,像睡著了一般拳氢。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蛋铆,一...
    開(kāi)封第一講書(shū)人閱讀 51,688評(píng)論 1 305
  • 那天馋评,我揣著相機(jī)與錄音,去河邊找鬼戒职。 笑死栗恩,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播磕秤,決...
    沈念sama閱讀 40,414評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼乳乌,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了市咆?” 一聲冷哼從身側(cè)響起汉操,我...
    開(kāi)封第一講書(shū)人閱讀 39,319評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎蒙兰,沒(méi)想到半個(gè)月后磷瘤,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,775評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡搜变,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年采缚,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片挠他。...
    茶點(diǎn)故事閱讀 40,096評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡扳抽,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出殖侵,到底是詐尸還是另有隱情贸呢,我是刑警寧澤,帶...
    沈念sama閱讀 35,789評(píng)論 5 346
  • 正文 年R本政府宣布拢军,位于F島的核電站楞陷,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏茉唉。R本人自食惡果不足惜固蛾,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,437評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望赌渣。 院中可真熱鬧魏铅,春花似錦、人聲如沸坚芜。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,993評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)鸿竖。三九已至沧竟,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間缚忧,已是汗流浹背悟泵。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,107評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留闪水,地道東北人糕非。 一個(gè)月前我還...
    沈念sama閱讀 48,308評(píng)論 3 372
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親朽肥。 傳聞我的和親對(duì)象是個(gè)殘疾皇子禁筏,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,037評(píng)論 2 355