@sum-ui/layout

测试标题
admin
container
@copyRight by footer
<template>
  <sum-layout :settings="settings" class="sum-layout">
     <template #title>
       <div class="title">
        <img style="height: 50px;margin-right: 10px;" src="">
        <div>测试标题</div>
       </div>
     </template>
     <template #right>
        <div>admin</div>
      </template>
      <template #default>
        <div>container</div>
      </template>
  </sum-layout>
</template>

<script lang="ts">
import { defineComponent, reactive, toRefs } from 'vue'

export default defineComponent({
  setup() {
    const settings = reactive({
        // 可以用slot插槽或者render渲染函数两种方式,当使用render的时候需要改成 <script lang="tsx">
        headerTitle: {
          slot: 'title'
        },
        // headerTitle: () => 
        //        <div class="title">
        //           <img
        //             src="./logo.png"
        //             alt="header-logo"
        //             />
        //             <div>测试标题</div>
        //        </div>,
        headerRight: {
          slot: 'right'
        },
        // headerRight: () => <div>admin</div>,
        menuData: [
          {
            title: '菜单列表', // 标题
            icon: 'el-icon-s-goods', // icon
            auth: 'menu', // 权限
            path: '/menu', // 路径
            children: [ // 子菜单
              {
                title: '数据',
                auth: 'menu/data',
                // path: '/menu/data'
              },
              {
                title: '分析',
                auth: 'menu/analysis',
                // path: '/menu/analysis'
              }
            ]
          }
       ],
       headerStyles: {
         backgroundColor: '#545c64',
         padding: '10px',
         color: '#fff'
       },
       menuProps: {
         backgroundColor: '#f7f6f2',
         textColor: '#333',
         activeTextColor: '#409eff',
         defaultActive: '0-0',
         defaultOpeneds: [0]
       },
       triggerCollapse: true,
       footer: '@copyRight by footer', // 字符串或者render函数
    })
    return {
      settings,
      ...toRefs(settings)
    }
  }
})
</script>

<style>
.sum-layout {
   min-height: 500px;
}
.title {
  display: flex;
  align-items: center;
}
a:hover {
  text-decoration: none!important;
}
</style>

SumLayout Attributes

参数说明类型可选值默认值
settings布局参数object{}

Settings Attributes

参数说明类型可选值默认值
headerTitle头栏左边内容string/object/function(如果有rener函数则展示render函数内容,如果是object,{slot: 'title'}则可以使用插槽,否则展示字符串){}
headerRight头栏右边内容string/object/function(如果有rener函数则展示render函数内容,如果是object,{slot: 'title'}则可以使用插槽,否则展示字符串){}
headerStyles头栏样式object{}
menuProps侧栏属性传递(继承 el-menu 属性)object{}
triggerCollapse是否显示 collapse 图标booleanfalse
menuData菜单数据array[]
footer底部footerstring/object/function(如果有rener函数则展示render函数内容,如果是object,{slot: 'title'}则可以使用插槽,否则展示字符串){}
参数说明类型可选值默认值
mode模式stringhorizontal / verticalvertical
collapse是否水平折叠收起菜单(仅在 mode 为 vertical 时可用)booleanfalse
background-color菜单的背景色(仅支持 hex 格式)string#ffffff
text-color菜单的文字颜色(仅支持 hex 格式)string#303133
active-text-color当前激活菜单的文字颜色(仅支持 hex 格式)string#409EFF
default-active当前激活菜单的 indexstring
default-openeds当前打开的 sub-menu 的 index 的数组Array
unique-opened是否只保持一个子菜单的展开booleanfalse
menu-trigger子菜单打开的触发方式(只在 mode 为 horizontal 时有效)stringhover / clickhover
router是否使用 vue-router 的模式,启用该模式会在激活导航时以 index 作为 path 进行路由跳转booleanfalse
collapse-transition是否开启折叠动画booleantrue
上次更新: 9/7/2021, 2:16:11 PM
贡献者: ltt