Skip to content

Commit 80330c0

Browse files
author
puhui999
committed
代码生成:新增主子表(erp模式)生成示例
1 parent 97edab4 commit 80330c0

File tree

7 files changed

+945
-0
lines changed

7 files changed

+945
-0
lines changed

src/api/infra/demo03-erp.js

Lines changed: 141 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,141 @@
1+
import request from '@/utils/request'
2+
3+
// 创建学生
4+
export function createDemo03Student(data) {
5+
return request({
6+
url: '/infra/demo03-student/create',
7+
method: 'post',
8+
data: data
9+
})
10+
}
11+
12+
// 更新学生
13+
export function updateDemo03Student(data) {
14+
return request({
15+
url: '/infra/demo03-student/update',
16+
method: 'put',
17+
data: data
18+
})
19+
}
20+
21+
// 删除学生
22+
export function deleteDemo03Student(id) {
23+
return request({
24+
url: '/infra/demo03-student/delete?id=' + id,
25+
method: 'delete'
26+
})
27+
}
28+
29+
// 获得学生
30+
export function getDemo03Student(id) {
31+
return request({
32+
url: '/infra/demo03-student/get?id=' + id,
33+
method: 'get'
34+
})
35+
}
36+
37+
// 获得学生分页
38+
export function getDemo03StudentPage(params) {
39+
return request({
40+
url: '/infra/demo03-student/page',
41+
method: 'get',
42+
params
43+
})
44+
}
45+
// 导出学生 Excel
46+
export function exportDemo03StudentExcel(params) {
47+
return request({
48+
url: '/infra/demo03-student/export-excel',
49+
method: 'get',
50+
params,
51+
responseType: 'blob'
52+
})
53+
}
54+
55+
// ==================== 子表(学生课程) ====================
56+
57+
// 获得学生课程分页
58+
export function getDemo03CoursePage(params) {
59+
return request({
60+
url: '/infra/demo03-student/demo03-course/page',
61+
method: 'get',
62+
params
63+
})
64+
}
65+
// 新增学生课程
66+
export function createDemo03Course(data) {
67+
return request({
68+
url: `/infra/demo03-student/demo03-course/create`,
69+
method: 'post',
70+
data
71+
})
72+
}
73+
74+
// 修改学生课程
75+
export function updateDemo03Course(data) {
76+
return request({
77+
url: `/infra/demo03-student/demo03-course/update`,
78+
method: 'post',
79+
data
80+
})
81+
}
82+
83+
// 删除学生课程
84+
export function deleteDemo03Course(id) {
85+
return request({
86+
url: `/infra/demo03-student/demo03-course/delete?id=` + id,
87+
method: 'delete'
88+
})
89+
}
90+
91+
// 获得学生课程
92+
export function getDemo03Course(id) {
93+
return request({
94+
url: `/infra/demo03-student/demo03-course/get?id=` + id,
95+
method: 'get'
96+
})
97+
}
98+
99+
// ==================== 子表(学生班级) ====================
100+
101+
// 获得学生班级分页
102+
export function getDemo03GradePage(params) {
103+
return request({
104+
url: '/infra/demo03-student/demo03-grade/page',
105+
method: 'get',
106+
params
107+
})
108+
}
109+
// 新增学生班级
110+
export function createDemo03Grade(data) {
111+
return request({
112+
url: `/infra/demo03-student/demo03-grade/create`,
113+
method: 'post',
114+
data
115+
})
116+
}
117+
118+
// 修改学生班级
119+
export function updateDemo03Grade(data) {
120+
return request({
121+
url: `/infra/demo03-student/demo03-grade/update`,
122+
method: 'post',
123+
data
124+
})
125+
}
126+
127+
// 删除学生班级
128+
export function deleteDemo03Grade(id) {
129+
return request({
130+
url: `/infra/demo03-student/demo03-grade/delete?id=` + id,
131+
method: 'delete'
132+
})
133+
}
134+
135+
// 获得学生班级
136+
export function getDemo03Grade(id) {
137+
return request({
138+
url: `/infra/demo03-student/demo03-grade/get?id=` + id,
139+
method: 'get'
140+
})
141+
}
Lines changed: 134 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,134 @@
1+
<template>
2+
<div class="app-container">
3+
<!-- 对话框(添加 / 修改) -->
4+
<el-dialog :title="dialogTitle" :visible.sync="dialogVisible" width="45%" v-dialogDrag append-to-body>
5+
<el-form ref="formRef" :model="formData" :rules="formRules" v-loading="formLoading" label-width="100px">
6+
<el-form-item label="名字" prop="name">
7+
<el-input v-model="formData.name" placeholder="请输入名字" />
8+
</el-form-item>
9+
<el-form-item label="性别" prop="sex">
10+
<el-radio-group v-model="formData.sex">
11+
<el-radio v-for="dict in this.getDictDatas(DICT_TYPE.SYSTEM_USER_SEX)"
12+
:key="dict.value" :label="parseInt(dict.value)"
13+
>{{dict.label}}</el-radio>
14+
</el-radio-group>
15+
</el-form-item>
16+
<el-form-item label="出生日期" prop="birthday">
17+
<el-date-picker clearable v-model="formData.birthday" type="date" value-format="timestamp" placeholder="选择出生日期" />
18+
</el-form-item>
19+
<el-form-item label="简介">
20+
<Editor v-model="formData.description" :min-height="192"/>
21+
</el-form-item>
22+
</el-form>
23+
<div slot="footer" class="dialog-footer">
24+
<el-button type="primary" @click="submitForm" :disabled="formLoading">确 定</el-button>
25+
<el-button @click="dialogVisible = false">取 消</el-button>
26+
</div>
27+
</el-dialog>
28+
</div>
29+
</template>
30+
31+
<script>
32+
import * as Demo03StudentApi from '@/api/infra/demo03-erp'
33+
import Editor from '@/components/Editor';
34+
export default {
35+
name: "Demo03StudentForm",
36+
components: {
37+
Editor,
38+
},
39+
data() {
40+
return {
41+
// 弹出层标题
42+
dialogTitle: "",
43+
// 是否显示弹出层
44+
dialogVisible: false,
45+
// 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
46+
formLoading: false,
47+
// 表单参数
48+
formData: {
49+
id: undefined,
50+
name: undefined,
51+
sex: undefined,
52+
birthday: undefined,
53+
description: undefined,
54+
},
55+
// 表单校验
56+
formRules: {
57+
name: [{ required: true, message: '名字不能为空', trigger: 'blur' }],
58+
sex: [{ required: true, message: '性别不能为空', trigger: 'blur' }],
59+
birthday: [{ required: true, message: '出生日期不能为空', trigger: 'blur' }],
60+
description: [{ required: true, message: '简介不能为空', trigger: 'blur' }],
61+
},
62+
};
63+
},
64+
methods: {
65+
/** 打开弹窗 */
66+
open(id) {
67+
this.dialogVisible = true;
68+
this.reset();
69+
const that = this;
70+
// 修改时,设置数据
71+
if (id) {
72+
this.formLoading = true;
73+
try {
74+
Demo03StudentApi.getDemo03Student(id).then(res=>{
75+
that.formData = res.data;
76+
that.title = "修改学生";
77+
})
78+
} finally {
79+
this.formLoading = false;
80+
}
81+
}
82+
this.title = "新增学生";
83+
},
84+
/** 提交按钮 */
85+
submitForm() {
86+
this.formLoading = true;
87+
try {
88+
const that = this;
89+
let data = this.formData;
90+
let validate = false;
91+
// 校验主表
92+
this.getRef("formRef").validate(valid => {
93+
validate = valid;
94+
});
95+
// 所有表单校验通过后方可提交
96+
if (!validate) {
97+
return;
98+
}
99+
// 修改的提交
100+
if (data.id) {
101+
Demo03StudentApi.updateDemo03Student(data).then(response => {
102+
that.$modal.msgSuccess("修改成功");
103+
that.dialogVisible = false;
104+
that.$emit('success');
105+
});
106+
return;
107+
}
108+
// 添加的提交
109+
Demo03StudentApi.createDemo03Student(data).then(response => {
110+
that.$modal.msgSuccess("新增成功");
111+
that.dialogVisible = false;
112+
that.$emit('success');
113+
});
114+
}finally {
115+
this.formLoading = false;
116+
}
117+
},
118+
getRef(refName){ // TODO puhui999: 获得表单 ref,提取出来的目的呢是解决 $ 在 if 中 end闭合不了的问题,代码生成后可删除此方法
119+
return this.$refs[refName]
120+
},
121+
/** 表单重置 */
122+
reset() {
123+
this.formData = {
124+
id: undefined,
125+
name: undefined,
126+
sex: undefined,
127+
birthday: undefined,
128+
description: undefined,
129+
};
130+
this.resetForm("formRef");
131+
},
132+
}
133+
};
134+
</script>
Lines changed: 112 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,112 @@
1+
<template>
2+
<div class="app-container">
3+
<!-- 对话框(添加 / 修改) -->
4+
<el-dialog :title="dialogTitle" :visible.sync="dialogVisible" width="45%" v-dialogDrag append-to-body>
5+
<el-form ref="formRef" :model="formData" :rules="formRules" v-loading="formLoading" label-width="100px">
6+
<el-form-item label="名字" prop="name">
7+
<el-input v-model="formData.name" placeholder="请输入名字" />
8+
</el-form-item>
9+
<el-form-item label="分数" prop="score">
10+
<el-input v-model="formData.score" placeholder="请输入分数" />
11+
</el-form-item>
12+
</el-form>
13+
<div slot="footer" class="dialog-footer">
14+
<el-button type="primary" @click="submitForm" :disabled="formLoading">确 定</el-button>
15+
<el-button @click="dialogVisible = false">取 消</el-button>
16+
</div>
17+
</el-dialog>
18+
</div>
19+
</template>
20+
21+
<script>
22+
import * as Demo03StudentApi from '@/api/infra/demo03-erp'
23+
export default {
24+
name: "Demo03CourseForm",
25+
components: {
26+
},
27+
data() {
28+
return {
29+
// 弹出层标题
30+
dialogTitle: "",
31+
// 是否显示弹出层
32+
dialogVisible: false,
33+
// 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
34+
formLoading: false,
35+
// 表单参数
36+
formData: {
37+
id: undefined,
38+
studentId: undefined,
39+
name: undefined,
40+
score: undefined,
41+
},
42+
// 表单校验
43+
formRules: {
44+
studentId: [{ required: true, message: "学生编号不能为空", trigger: "blur" }],
45+
name: [{ required: true, message: "名字不能为空", trigger: "blur" }],
46+
score: [{ required: true, message: "分数不能为空", trigger: "blur" }],
47+
},
48+
};
49+
},
50+
methods: {
51+
/** 打开弹窗 */
52+
open(id, studentId) {
53+
this.dialogVisible = true;
54+
this.reset();
55+
const that = this;
56+
this.formData.studentId = studentId;
57+
// 修改时,设置数据
58+
if (id) {
59+
this.formLoading = true;
60+
try {
61+
Demo03StudentApi.getDemo03Course(id).then(res=>{
62+
that.formData = res.data;
63+
that.dialogTitle = "修改学生课程";
64+
})
65+
} finally {
66+
this.formLoading = false;
67+
}
68+
}
69+
this.dialogTitle = "新增学生课程";
70+
},
71+
/** 提交按钮 */
72+
submitForm() {
73+
this.formLoading = true;
74+
try {
75+
let data = this.formData;
76+
this.$refs["formRef"].validate(valid => {
77+
if (!valid) {
78+
return;
79+
}
80+
// 修改的提交
81+
if (data.id) {
82+
Demo03StudentApi.updateDemo03Course(data).then(response => {
83+
this.$modal.msgSuccess("修改成功");
84+
this.dialogVisible = false;
85+
this.$emit('success');
86+
});
87+
return;
88+
}
89+
// 添加的提交
90+
Demo03StudentApi.createDemo03Course(data).then(response => {
91+
this.$modal.msgSuccess("新增成功");
92+
this.dialogVisible = false;
93+
this.$emit('success');
94+
});
95+
});
96+
}finally {
97+
this.formLoading = false
98+
}
99+
},
100+
/** 表单重置 */
101+
reset() {
102+
this.formData = {
103+
id: undefined,
104+
studentId: undefined,
105+
name: undefined,
106+
score: undefined,
107+
};
108+
this.resetForm("formRef");
109+
},
110+
}
111+
};
112+
</script>

0 commit comments

Comments
 (0)