fix(watch): fix flush: pre watchers triggered synchronously in setup

fix #5721
This commit is contained in:
Evan You
2022-04-15 18:08:44 +08:00
parent 82bdf86254
commit 74d2a76af6
3 changed files with 32 additions and 10 deletions

View File

@@ -18,7 +18,8 @@ import {
h,
createApp,
watchPostEffect,
watchSyncEffect
watchSyncEffect,
onMounted
} from '@vue/runtime-test'
import {
ITERATE_KEY,
@@ -581,6 +582,33 @@ describe('api: watch', () => {
expect(calls).toEqual(['render', 'watcher 1', 'watcher 2', 'render'])
})
// #5721
it('flush: pre triggered in component setup should be buffered and called before mounted', () => {
const count = ref(0)
const calls: string[] = []
const App = {
render() {},
setup() {
watch(
count,
() => {
calls.push('watch ' + count.value)
},
{ flush: 'pre' }
)
onMounted(() => {
calls.push('mounted')
})
// mutate multiple times
count.value++
count.value++
count.value++
}
}
render(h(App), nodeOps.createElement('div'))
expect(calls).toMatchObject(['watch 3', 'mounted'])
})
// #1852
it('flush: post watcher should fire after template refs updated', async () => {
const toggle = ref(false)