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

@@ -345,15 +345,7 @@ function doWatch(
scheduler = () => queuePostRenderEffect(job, instance && instance.suspense)
} else {
// default: 'pre'
scheduler = () => {
if (!instance || instance.isMounted) {
queuePreFlushCb(job)
} else {
// with 'pre' option, the first call must happen before
// the component is mounted so it is called synchronously.
job()
}
}
scheduler = () => queuePreFlushCb(job)
}
const effect = new ReactiveEffect(getter, scheduler)

View File

@@ -182,6 +182,8 @@ export function flushPreFlushCbs(
}
export function flushPostFlushCbs(seen?: CountMap) {
// flush any pre cbs queued during the flush (e.g. pre watchers)
flushPreFlushCbs()
if (pendingPostFlushCbs.length) {
const deduped = [...new Set(pendingPostFlushCbs)]
pendingPostFlushCbs.length = 0