diff --git a/src/runtime/composables/ssr-ref.ts b/src/runtime/composables/ssr-ref.ts index d44c86f8..825ee85e 100644 --- a/src/runtime/composables/ssr-ref.ts +++ b/src/runtime/composables/ssr-ref.ts @@ -25,27 +25,20 @@ export function setSSRContext(app: any) { } const useServerData = () => { - let type: 'globalRefs' | 'ssrRefs' = 'globalRefs' - const vm = getCurrentInstance() + const type: 'globalRefs' | 'ssrRefs' = vm ? 'ssrRefs' : 'globalRefs' - if (vm) { - type = 'ssrRefs' - if (process.server) { - const { ssrContext } = (vm[globalNuxt] || vm.$options).context - ;(ssrContext as any).nuxt.ssrRefs = (ssrContext as any).nuxt.ssrRefs || {} - } + let ssrRefs: Record + + if (vm && process.server) { + const ssrContext = (vm![globalNuxt] || vm!.$options).context.ssrContext! + ssrRefs = (ssrContext.nuxt as any).ssrRefs = + (ssrContext.nuxt as any).ssrRefs || {} } const setData = (key: string, val: any) => { - switch (type) { - case 'globalRefs': - globalRefs[key] = sanitise(val) - break - case 'ssrRefs': - ;(vm![globalNuxt].context.ssrContext as any).nuxt.ssrRefs[key] = - sanitise(val) - } + const refs = ssrRefs || globalRefs + refs[key] = sanitise(val) } return { type, setData } diff --git a/test/fixture/plugins/global.js b/test/fixture/plugins/global.js index 44b29d0a..41e83264 100644 --- a/test/fixture/plugins/global.js +++ b/test/fixture/plugins/global.js @@ -16,7 +16,8 @@ export default () => { onGlobalSetup(() => { const { $config } = useContext() - ssrRef('test') + const a = ssrRef('test') + a.value = 'another' const { title } = useMeta() title.value = 'My fixture'