From db9c566032da0ec5cd758a3e8525e9733874c1e5 Mon Sep 17 00:00:00 2001 From: Evan You Date: Thu, 14 Dec 2023 09:21:11 +0800 Subject: [PATCH] fix: account for nested render calls close #13131 --- src/core/instance/render.ts | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/src/core/instance/render.ts b/src/core/instance/render.ts index b71125b275..6553f21748 100644 --- a/src/core/instance/render.ts +++ b/src/core/instance/render.ts @@ -15,7 +15,7 @@ import VNode, { createEmptyVNode } from '../vdom/vnode' import { isUpdatingChildComponent } from './lifecycle' import type { Component } from 'types/component' -import { setCurrentInstance } from 'v3/currentInstance' +import { currentInstance, setCurrentInstance } from 'v3/currentInstance' import { syncSetupSlots } from 'v3/apiSetup' export function initRender(vm: Component) { @@ -120,11 +120,10 @@ export function renderMixin(Vue: typeof Component) { // to the data on the placeholder node. vm.$vnode = _parentVnode! // render self + const prevInst = currentInstance + const prevRenderInst = currentRenderingInstance let vnode try { - // There's no need to maintain a stack because all render fns are called - // separately from one another. Nested component's render fns are called - // when parent component is patched. setCurrentInstance(vm) currentRenderingInstance = vm vnode = render.call(vm._renderProxy, vm.$createElement) @@ -148,8 +147,8 @@ export function renderMixin(Vue: typeof Component) { vnode = vm._vnode } } finally { - currentRenderingInstance = null - setCurrentInstance() + currentRenderingInstance = prevRenderInst + setCurrentInstance(prevInst) } // if the returned array contains only a single node, allow it if (isArray(vnode) && vnode.length === 1) {