setPageLayout
setPageLayout 允许你动态更改页面的布局。
setPageLayout 允许你动态更改页面的布局。它依赖于对 Nuxt 上下文的访问,因此只能在 Nuxt 上下文 中调用。middleware/custom-layout.ts
export default defineNuxtRouteMiddleware((to) => {
// 设置你要导航到的路由的布局
setPageLayout('other')
})
传递 Props 给布局
你可以通过提供一个对象作为第二个参数来向布局传递 props:
middleware/admin-layout.ts
export default defineNuxtRouteMiddleware((to) => {
setPageLayout('admin', {
sidebar: true,
title: 'Dashboard',
})
})
布局组件随后可以接收这些 props:
layouts/admin.vue
<script setup lang="ts">
const props = defineProps<{
sidebar?: boolean
title?: string
}>()
</script>
<template>
<div>
<aside v-if="sidebar">
侧边栏
</aside>
<main>
<h1>{{ title }}</h1>
<slot />
</main>
</div>
</template>
如果你选择在服务器端动态设置布局,必须在 Vue 渲染布局之前完成(即,在插件或路由中间件内进行),以避免水合不匹配的问题。