fix(runtime-core): fix beforeUpdate call timing to allow state mutation
fix #1899
This commit is contained in:
parent
24041b7ac1
commit
1eb6067a85
@ -74,6 +74,36 @@ describe('api: lifecycle hooks', () => {
|
|||||||
count.value++
|
count.value++
|
||||||
await nextTick()
|
await nextTick()
|
||||||
expect(fn).toHaveBeenCalledTimes(1)
|
expect(fn).toHaveBeenCalledTimes(1)
|
||||||
|
expect(serializeInner(root)).toBe(`<div>1</div>`)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('state mutation in onBeforeUpdate', async () => {
|
||||||
|
const count = ref(0)
|
||||||
|
const root = nodeOps.createElement('div')
|
||||||
|
const fn = jest.fn(() => {
|
||||||
|
// should be called before inner div is updated
|
||||||
|
expect(serializeInner(root)).toBe(`<div>0</div>`)
|
||||||
|
count.value++
|
||||||
|
})
|
||||||
|
const renderSpy = jest.fn()
|
||||||
|
|
||||||
|
const Comp = {
|
||||||
|
setup() {
|
||||||
|
onBeforeUpdate(fn)
|
||||||
|
return () => {
|
||||||
|
renderSpy()
|
||||||
|
return h('div', count.value)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
render(h(Comp), root)
|
||||||
|
expect(renderSpy).toHaveBeenCalledTimes(1)
|
||||||
|
|
||||||
|
count.value++
|
||||||
|
await nextTick()
|
||||||
|
expect(fn).toHaveBeenCalledTimes(1)
|
||||||
|
expect(renderSpy).toHaveBeenCalledTimes(2)
|
||||||
|
expect(serializeInner(root)).toBe(`<div>2</div>`)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('onUpdated', async () => {
|
it('onUpdated', async () => {
|
||||||
|
@ -1281,13 +1281,7 @@ function baseCreateRenderer(
|
|||||||
let vnodeHook: VNodeHook | null | undefined
|
let vnodeHook: VNodeHook | null | undefined
|
||||||
const { el, props } = initialVNode
|
const { el, props } = initialVNode
|
||||||
const { bm, m, parent } = instance
|
const { bm, m, parent } = instance
|
||||||
if (__DEV__) {
|
|
||||||
startMeasure(instance, `render`)
|
|
||||||
}
|
|
||||||
const subTree = (instance.subTree = renderComponentRoot(instance))
|
|
||||||
if (__DEV__) {
|
|
||||||
endMeasure(instance, `render`)
|
|
||||||
}
|
|
||||||
// beforeMount hook
|
// beforeMount hook
|
||||||
if (bm) {
|
if (bm) {
|
||||||
invokeArrayFns(bm)
|
invokeArrayFns(bm)
|
||||||
@ -1296,6 +1290,16 @@ function baseCreateRenderer(
|
|||||||
if ((vnodeHook = props && props.onVnodeBeforeMount)) {
|
if ((vnodeHook = props && props.onVnodeBeforeMount)) {
|
||||||
invokeVNodeHook(vnodeHook, parent, initialVNode)
|
invokeVNodeHook(vnodeHook, parent, initialVNode)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// render
|
||||||
|
if (__DEV__) {
|
||||||
|
startMeasure(instance, `render`)
|
||||||
|
}
|
||||||
|
const subTree = (instance.subTree = renderComponentRoot(instance))
|
||||||
|
if (__DEV__) {
|
||||||
|
endMeasure(instance, `render`)
|
||||||
|
}
|
||||||
|
|
||||||
if (el && hydrateNode) {
|
if (el && hydrateNode) {
|
||||||
if (__DEV__) {
|
if (__DEV__) {
|
||||||
startMeasure(instance, `hydrate`)
|
startMeasure(instance, `hydrate`)
|
||||||
@ -1365,6 +1369,18 @@ function baseCreateRenderer(
|
|||||||
} else {
|
} else {
|
||||||
next = vnode
|
next = vnode
|
||||||
}
|
}
|
||||||
|
next.el = vnode.el
|
||||||
|
|
||||||
|
// beforeUpdate hook
|
||||||
|
if (bu) {
|
||||||
|
invokeArrayFns(bu)
|
||||||
|
}
|
||||||
|
// onVnodeBeforeUpdate
|
||||||
|
if ((vnodeHook = next.props && next.props.onVnodeBeforeUpdate)) {
|
||||||
|
invokeVNodeHook(vnodeHook, parent, next, vnode)
|
||||||
|
}
|
||||||
|
|
||||||
|
// render
|
||||||
if (__DEV__) {
|
if (__DEV__) {
|
||||||
startMeasure(instance, `render`)
|
startMeasure(instance, `render`)
|
||||||
}
|
}
|
||||||
@ -1374,15 +1390,7 @@ function baseCreateRenderer(
|
|||||||
}
|
}
|
||||||
const prevTree = instance.subTree
|
const prevTree = instance.subTree
|
||||||
instance.subTree = nextTree
|
instance.subTree = nextTree
|
||||||
next.el = vnode.el
|
|
||||||
// beforeUpdate hook
|
|
||||||
if (bu) {
|
|
||||||
invokeArrayFns(bu)
|
|
||||||
}
|
|
||||||
// onVnodeBeforeUpdate
|
|
||||||
if ((vnodeHook = next.props && next.props.onVnodeBeforeUpdate)) {
|
|
||||||
invokeVNodeHook(vnodeHook, parent, next, vnode)
|
|
||||||
}
|
|
||||||
// reset refs
|
// reset refs
|
||||||
// only needed if previous patch had refs
|
// only needed if previous patch had refs
|
||||||
if (instance.refs !== EMPTY_OBJ) {
|
if (instance.refs !== EMPTY_OBJ) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user