【Nuxt】Layout 布局和渲染模式

NuxtLayout

app.vue

vue 复制代码
  <NuxtLayout>
    <NuxtPage/>
  </NuxtLayout>

然后默认的布局 需要 写在 ~/layouts/default.vue 下面,其他自定义的布局也在写在 layouts 目录下。

default.vue

vue 复制代码
<template>
  <div class="app-container">
    <div class="header">Header</div>
    <slot></slot>
    <div class="footer">Footer</div>
  </div>
</template>
<script setup>

</script>
<style scoped>
.header {
  background-color: #6dedc4;
  padding: 10px;
  text-align: center;
}
.footer {
  background-color: #55abd2;
  padding: 10px;
  text-align: center;
}
</style>

这样所有页面都使用了 默认布局,slot 插槽里面内容是路由变化带来的。

如果不希望所有页面都使用默认布局,还可以用 自定义布局:

login.vue

vue 复制代码
<script setup lang="ts">
definePageMeta({
  layout: 'custom'
})
</script>

<template>
<div>login</div>
</template>

<style scoped>

</style>

custom.vue

vue 复制代码
<script setup lang="ts">

</script>

<template>
  <div>
    <p>自定义布局</p>
    <slot />
  </div>
</template>

<style scoped>

</style>

此外 NuxtLayout 还有一个属性 name, 可以指定某个样式作为内部 NuxtPage 的布局,但是它的优先级要高于 definePageMeta.layout 。

所以如果给上述加上 name,则 login 页面的自定义布局失效。

渲染模式

ts 复制代码
    // ssr: false,
    // Experimental API
    routeRules: {
        '/': {ssr: true},
        '/about': {ssr: false},
        '/cart': {static: true}, // 只会在构建时生成一次静态页面
        '/checkout': {swr: true}, // 只会生成多次静态页面 自动重新验证页面的时候需要重新生成
    }
相关推荐
谷谷地图下载器6 小时前
全球、台湾省的无水印·街景数据(离线数据),专为可视化项目定制,支持国产化
javascript·c++·3d·arcgis·sqlite
万少6 小时前
如果你要自动化操作浏览器,Kimi-WebBridge可能适合你
前端·javascript·后端
dinl_vin6 小时前
Python 并发编程实战:多线程、协程与多进程全解析
开发语言·人工智能·python
程序大视界6 小时前
【C++ 从基础到项目实战】C++(五):类与对象基础——构造、析构与访问控制
开发语言·c++·cpp
代码中介商6 小时前
掌握C++ std::bind:参数绑定与灵活调用
开发语言·c++
拽着尾巴的鱼儿6 小时前
Java 对象的深拷贝和浅拷贝
java·开发语言
韩曙亮7 小时前
【错误记录】flutter attach 附加设备 执行报错 ( 附加设备注意事项 )
android·javascript·flutter·flutter attach
fie88897 小时前
matlab打靶法求解两点边值优化问题
开发语言·算法·matlab
数据法师7 小时前
Alger Music Player 技术深度解析:基于 Electron + Vue 3 的开源网易云第三方客户端
vue.js·electron·开源
skywalk81637 小时前
请结合以下说明,先完成类似python的内置函数。 然后再去完成内置库(标准款) ‌内置函数‌
开发语言·python