fix(runtime-core/scheduler): sort postFlushCbs to ensure refs are set before lifecycle hooks (#1854)

fix #1852
This commit is contained in:
HcySunYang
2020-08-14 21:50:23 +08:00
committed by GitHub
parent 3fa5c9fdab
commit caccec3f78
4 changed files with 77 additions and 19 deletions

View File

@@ -7,7 +7,7 @@ import {
ref,
h
} from '../src/index'
import { render, nodeOps, serializeInner } from '@vue/runtime-test'
import { render, nodeOps, serializeInner, TestElement } from '@vue/runtime-test'
import {
ITERATE_KEY,
DebuggerEvent,
@@ -484,6 +484,37 @@ describe('api: watch', () => {
expect(calls).toEqual(['render', 'watcher 1', 'watcher 2', 'render'])
})
// #1852
it('flush: post watcher should fire after template refs updated', async () => {
const toggle = ref(false)
let dom: TestElement | null = null
const App = {
setup() {
const domRef = ref<TestElement | null>(null)
watch(
toggle,
() => {
dom = domRef.value
},
{ flush: 'post' }
)
return () => {
return toggle.value ? h('p', { ref: domRef }) : null
}
}
}
render(h(App), nodeOps.createElement('div'))
expect(dom).toBe(null)
toggle.value = true
await nextTick()
expect(dom!.tag).toBe('p')
})
it('deep', async () => {
const state = reactive({
nested: {