閃爍是一個(gè)令人非常不快的現(xiàn)象。這種現(xiàn)象可能會(huì)發(fā)生在不經(jīng)常更新的網(wǎng)站或使用令人討厭的Flash和JavaScript動(dòng)畫的網(wǎng)站上。在Vue中,閃爍問(wèn)題是可能發(fā)生的,但值得注意的是,它不是Vue or JavaScript引起的問(wèn)題,而是由瀏覽器操作引起的。由于Vue的“響應(yīng)式”能力,更新數(shù)據(jù)時(shí),會(huì)觸發(fā)重新渲染。然而,由于渲染的機(jī)制,因此出現(xiàn)頁(yè)面閃爍。
{{ message }}
讓我們使用上述代碼作為示例。在Vue實(shí)例的創(chuàng)建鉤子中,我們?cè)O(shè)置一個(gè)計(jì)時(shí)器。5秒后,該計(jì)時(shí)器將更新this.message,并將其從“Hello,world!”更改為“Goodbye,world!”這會(huì)觸發(fā)重新渲染,可能導(dǎo)致頁(yè)面閃爍問(wèn)題。
解決這個(gè)問(wèn)題的一種方法是使用v-cloak指令。這會(huì)在Vue準(zhǔn)備好渲染最終頁(yè)面之前,將元素隱藏起來(lái)。然后,Vue從中移除v-cloak指令。節(jié)點(diǎn)上的CSS設(shè)置保留,因此在節(jié)點(diǎn)可見(jiàn)之前,會(huì)隱藏該元素。因此,它有效地解決了閃爍的問(wèn)題。
{{ message }}[v-cloak] { display: none; }
如上所示,我們將v-cloak指令應(yīng)用于要放在頁(yè)面上的元素。在HTML中,我們也可以添加CSS,確保在Vue實(shí)例準(zhǔn)備好并刪除v-cloak指令之前,該元素不可見(jiàn)。在Vue實(shí)例渲染之后,使用v-cloak的元素將顯示在頁(yè)面上。
換句話說(shuō),v-cloak指令和上面的CSS代碼共同確保在Vue實(shí)例準(zhǔn)備好并刪除v-cloak指令之前,添加了該指令的元素不可見(jiàn)。這使其成為解決Vue閃爍問(wèn)題的良好解決方案。