<ClientOnly>
使用 <ClientOnly> 组件仅在客户端渲染组件。
<ClientOnly> 组件用于专门只在客户端渲染某个组件。
默认插槽的内容会在服务端构建时被树摇(tree-shaken)移除。(这意味着插槽内组件所使用的任何 CSS 可能不会在初始 HTML 渲染时内联。)
Props
placeholderTag|fallbackTag:指定服务端渲染时渲染的标签。placeholder|fallback:指定服务端渲染时渲染的内容。
<template>
  <div>
    <Sidebar />
    <!-- <Comment> 组件仅会在客户端渲染 -->
    <ClientOnly fallback-tag="span" fallback="加载评论中...">
      <Comment />
    </ClientOnly>
  </div>
</template>
插槽
#fallback:指定在服务端渲染并在浏览器中<ClientOnly>挂载前显示的内容。
pages/example.vue
<template>
  <div>
    <Sidebar />
    <!-- 这会在服务端渲染 "span" 元素 -->
    <ClientOnly fallbackTag="span">
      <!-- 该组件仅会在客户端渲染 -->
      <Comments />
      <template #fallback>
        <!-- 这会在服务端渲染 -->
        <p>加载评论中...</p>
      </template>
    </ClientOnly>
  </div>
</template>
示例
获取 HTML 元素访问权限
<ClientOnly> 中的组件只有在挂载后才会渲染。要访问 DOM 中渲染的元素,可以监听模板引用:
pages/example.vue
<script setup lang="ts">
const nuxtWelcomeRef = useTemplateRef('nuxtWelcomeRef')
// 组件可用时监听会被触发
watch(nuxtWelcomeRef, () => {
 console.log('<NuxtWelcome /> 已挂载')
}, { once: true })
</script>
<template>
  <ClientOnly>
    <NuxtWelcome ref="nuxtWelcomeRef" />
  </ClientOnly>
</template>