131 lines
3.3 KiB
Markdown
131 lines
3.3 KiB
Markdown
# 模版
|
||
|
||
## 基础框架
|
||
|
||
### 程序配置
|
||
|
||
核心配置为数据库配置:
|
||
|
||
```yaml
|
||
database:
|
||
address: "192.168.9.199:3306"
|
||
username: "root"
|
||
password: "root"
|
||
database: "test2"
|
||
|
||
adminUsers:
|
||
- "1000"
|
||
|
||
system:
|
||
settings:
|
||
productName: "测试网址"
|
||
copyright: "xxx"
|
||
```
|
||
|
||
**数据库配置**
|
||
|
||
| 配置节点 | 配置说明 |
|
||
|----------|---------|
|
||
| address | 数据库连接地址 |
|
||
| username | 数据库用户名 |
|
||
| password | 数据库密码 |
|
||
| database | 使用的数据库 |
|
||
|
||
**系统配置**
|
||
|
||
系统配置为键值对的格式,结合界面进行配置的
|
||
|
||
| 配置节点 | 配置说明 |
|
||
|-------------|-----------------|
|
||
| productName | 产品名称,对应界面的title |
|
||
| copyright | 版权信息 |
|
||
| logo | logo的Url地址 |
|
||
|
||
### 程序启动
|
||
|
||
如果设置了`VOX_DEBUG`环境变量会以`DEBUG`模式进行启动,常规启动方式为
|
||
|
||
```shell
|
||
moto --config=/path/to/config.yaml
|
||
```
|
||
|
||
## 开始开发
|
||
|
||
框架主要适用于多使用增删改查的操作逻辑,开发流程为定义模型,定义菜单,定制界面。
|
||
|
||
### 模型定义
|
||
|
||
|
||
```go
|
||
package models
|
||
|
||
type Login struct {
|
||
ID string `json:"id" gorm:"primaryKey;size:20" comment:"ID" scenarios:"view;export"`
|
||
CreatedAt int64 `json:"created_at" gorm:"autoCreateTime" comment:"登录时间" scenarios:"list;search;view;export" position:"2"`
|
||
Domain string `json:"domain" gorm:"index;size:60;not null;default:'default'" comment:"域" scenarios:"export"`
|
||
UID string `json:"uid" gorm:"column:uid;index;size:20;not null;default:''" props:"match:exactly" comment:"座席" format:"user" scenarios:"search;list;export" position:"1"`
|
||
IP string `json:"ip" gorm:"size:20;not null;default:''" comment:"IP" scenarios:"search;list;export"`
|
||
Browser string `json:"browser" gorm:"size:200;not null;default:''" comment:"浏览器" scenarios:"search;list;export"`
|
||
Os string `json:"os" gorm:"size:200;not null;default:''" comment:"操作系统" scenarios:"search;list;export"`
|
||
Platform string `json:"platform" gorm:"size:200;not null;default:''" comment:"平台" scenarios:"search;list;export"`
|
||
AccessToken string `json:"access_token" gorm:"size:200;not null;default:''" comment:"访问令牌" scenarios:"export"`
|
||
UserAgent string `json:"user_agent" gorm:"size:1024;not null;default:''" comment:"UserAgent" scenarios:"export"`
|
||
}
|
||
|
||
func (model *Login) TableName() string {
|
||
return "user_logins"
|
||
}
|
||
```
|
||
|
||
## 菜单定义
|
||
|
||
```js
|
||
let menu = {
|
||
label: "部门管理",
|
||
route: "/organize/departments",
|
||
permissions: [
|
||
{
|
||
label: '新建',
|
||
value: 'create'
|
||
},
|
||
{
|
||
label: '更新',
|
||
value: 'update'
|
||
},
|
||
{
|
||
label: '删除',
|
||
value: 'delete'
|
||
}
|
||
]
|
||
}
|
||
```
|
||
|
||
## 视图定义
|
||
|
||
```vue
|
||
<template>
|
||
<viewer :title="title" :module-name="moduleName" :table-name="tableName" :disable-toolbar="false"
|
||
defaultSortable="id"></viewer>
|
||
</template>
|
||
|
||
<script setup>
|
||
import Viewer from '@/components/fragment/Viewer.vue';
|
||
import { computed } from 'vue';
|
||
|
||
const props = defineProps({
|
||
title: {
|
||
type: String,
|
||
}
|
||
})
|
||
|
||
const moduleName = computed(() => {
|
||
return ''
|
||
})
|
||
|
||
const tableName = computed(() => {
|
||
return 'departments'
|
||
})
|
||
|
||
</script>
|
||
```
|