Skip to content

uni-helper/vite-plugin-uni-layouts

Repository files navigation

@uni-helper/vite-plugin-uni-layouts

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

只需声明一个 ref 变量 uniLayout 即可访问

<script setup>
const uniLayout = ref()
</script>

或者

<script>
export default {
  onLoad() {
    console.log(this.$refs.uniLayout)
  }
}
</script>

配置

see type.ts

注意

layout 插件并非使用了什么魔法,它只做了两件事:

  1. 自动扫描并全局注册 layouts 目录下的组件
  2. 将页面使用 layout 组件包裹起来 所以,在微信小程序下,如果你使用了 web-view , 那么不会生效。

如果你使用 vite-plugin-uni-pages, 只需使用 route-block

<route lang="json">
{
  "layout": "anyLayout"
}
</route>