<ClientOnly>
Render components only in client-side with the <ClientOnly> component.
The <ClientOnly>
component is used for purposely rendering a component only on client side.
The content of the default slot will be tree-shaken out of the server build. (This does mean that any CSS used by components within it may not be inlined when rendering the initial HTML.)
Props
placeholderTag
|fallbackTag
: specify a tag to be rendered server-side.placeholder
|fallback
: specify a content to be rendered server-side.
<template> <div> <Sidebar /> <!-- The <Comment> component will only be rendered on client-side --> <ClientOnly fallback-tag="span" fallback="Loading comments..."> <Comment /> </ClientOnly> </div> </template>
Slots
#fallback
: specify a content to be rendered on the server and displayed until<ClientOnly>
is mounted in the browser.
pages/example.vue
<template> <div> <Sidebar /> <!-- This renders the "span" element on the server side --> <ClientOnly fallbackTag="span"> <!-- this component will only be rendered on client side --> <Comments /> <template #fallback> <!-- this will be rendered on server side --> <p>Loading comments...</p> </template> </ClientOnly> </div> </template>
Examples
Accessing HTML Elements
Components inside <ClientOnly>
are rendered only after being mounted. To access the rendered elements in the DOM, you can watch a template ref:
pages/example.vue
<script setup lang="ts"> const nuxtWelcomeRef = useTemplateRef('nuxtWelcomeRef') // The watch will be triggered when the component is available watch(nuxtWelcomeRef, () => { console.log('<NuxtWelcome /> mounted') }, { once: true }) </script> <template> <ClientOnly> <NuxtWelcome ref="nuxtWelcomeRef" /> </ClientOnly> </template>