Vite 下 uni-app 的可定制布局框架
pnpm i -D @uni-helper/vite-plugin-uni-layouts// vite.config.ts
import { defineConfig } from 'vite'
import uni from '@dcloudio/vite-plugin-uni'
import UniLayouts from '@uni-helper/vite-plugin-uni-layouts'
export default defineConfig({
plugins: [UniLayouts(), uni()],
})在 src/layouts 下创建布局
<!-- default.vue -->
<template>
<slot>main</slot>
</template>在 pages.json 中的页面中添加 layout 配置
// pages.json
{
// ...
"pages": [{
"path": "pages/index/index",
// 可选, 这是默认值
"layout": "default"
}]
// ...
}// pages.json
{
// ...
"pages": [{
"path": "pages/index/index",
"layout": false
}]
// ...
}你需要先禁用页面的布局, 然后使用内置组件 <uni-layout />, 使用 name 属性指定布局,支持动态绑定 name、ref 等任意属性
<script setup>
const defaultName = ref('default')
</script>
<template>
<uni-layout :name="defaultName">
<template #header>uni-layout header</template>
use slot
<template #footer>uni-layout footer</template>
</uni-layout>
</template>只需声明一个 ref 变量 uniLayout 即可访问
<script setup>
const uniLayout = ref()
</script>或者
<script>
export default {
onLoad() {
console.log(this.$refs.uniLayout)
}
}
</script>see type.ts
layout 插件并非使用了什么魔法,它只做了两件事:
- 自动扫描并全局注册 layouts 目录下的组件
- 将页面使用 layout 组件包裹起来 所以,在微信小程序下,如果你使用了 web-view , 那么不会生效。
如果你使用 vite-plugin-uni-pages, 只需使用 route-block
<route lang="json">
{
"layout": "anyLayout"
}
</route>