Skip to content

Commit 938d0fb

Browse files
author
puhui999
committed
perf: 代码生成示例 inner 增加批量删除示例
1 parent 3c98abe commit 938d0fb

File tree

7 files changed

+162
-102
lines changed

7 files changed

+162
-102
lines changed

src/api/infra/demo03-inner.js

Lines changed: 16 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,7 @@ import request from '@/utils/request'
33
// 创建学生
44
export function createDemo03Student(data) {
55
return request({
6-
url: '/infra/demo03-student/create',
6+
url: '/infra/demo03-student-inner/create',
77
method: 'post',
88
data: data
99
})
@@ -12,7 +12,7 @@ export function createDemo03Student(data) {
1212
// 更新学生
1313
export function updateDemo03Student(data) {
1414
return request({
15-
url: '/infra/demo03-student/update',
15+
url: '/infra/demo03-student-inner/update',
1616
method: 'put',
1717
data: data
1818
})
@@ -21,53 +21,59 @@ export function updateDemo03Student(data) {
2121
// 删除学生
2222
export function deleteDemo03Student(id) {
2323
return request({
24-
url: '/infra/demo03-student/delete?id=' + id,
24+
url: '/infra/demo03-student-inner/delete?id=' + id,
25+
method: 'delete'
26+
})
27+
}
28+
29+
/** 批量删除学生 */
30+
export function deleteDemo03StudentList(ids) {
31+
return request({
32+
url: `/infra/demo03-student-inner/delete-list?ids=${ids.join(',')}`,
2533
method: 'delete'
2634
})
2735
}
2836

2937
// 获得学生
3038
export function getDemo03Student(id) {
3139
return request({
32-
url: '/infra/demo03-student/get?id=' + id,
40+
url: '/infra/demo03-student-inner/get?id=' + id,
3341
method: 'get'
3442
})
3543
}
3644

3745
// 获得学生分页
3846
export function getDemo03StudentPage(params) {
3947
return request({
40-
url: '/infra/demo03-student/page',
48+
url: '/infra/demo03-student-inner/page',
4149
method: 'get',
4250
params
4351
})
4452
}
4553
// 导出学生 Excel
4654
export function exportDemo03StudentExcel(params) {
4755
return request({
48-
url: '/infra/demo03-student/export-excel',
56+
url: '/infra/demo03-student-inner/export-excel',
4957
method: 'get',
5058
params,
5159
responseType: 'blob'
5260
})
5361
}
5462

5563
// ==================== 子表(学生课程) ====================
56-
5764
// 获得学生课程列表
5865
export function getDemo03CourseListByStudentId(studentId) {
5966
return request({
60-
url: `/infra/demo03-student/demo03-course/list-by-student-id?studentId=` + studentId,
67+
url: '/infra/demo03-student-inner/demo03-course/list-by-student-id?studentId=' + studentId,
6168
method: 'get'
6269
})
6370
}
6471

6572
// ==================== 子表(学生班级) ====================
66-
6773
// 获得学生班级
6874
export function getDemo03GradeByStudentId(studentId) {
6975
return request({
70-
url: `/infra/demo03-student/demo03-grade/get-by-student-id?studentId=` + studentId,
76+
url: '/infra/demo03-student-inner/demo03-grade/get-by-student-id?studentId=' + studentId,
7177
method: 'get'
7278
})
7379
}

src/views/infra/demo/demo03/inner/Demo03StudentForm.vue

Lines changed: 10 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -4,17 +4,19 @@
44
<el-dialog :title="dialogTitle" :visible.sync="dialogVisible" width="45%" v-dialogDrag append-to-body>
55
<el-form ref="formRef" :model="formData" :rules="formRules" v-loading="formLoading" label-width="100px">
66
<el-form-item label="名字" prop="name">
7-
<el-input v-model="formData.name" placeholder="请输入名字" />
7+
<el-input v-model="formData.name" placeholder="请输入名字"/>
88
</el-form-item>
99
<el-form-item label="性别" prop="sex">
1010
<el-radio-group v-model="formData.sex">
1111
<el-radio v-for="dict in this.getDictDatas(DICT_TYPE.SYSTEM_USER_SEX)"
1212
:key="dict.value" :label="parseInt(dict.value)"
13-
>{{dict.label}}</el-radio>
13+
>{{ dict.label }}
14+
</el-radio>
1415
</el-radio-group>
1516
</el-form-item>
1617
<el-form-item label="出生日期" prop="birthday">
17-
<el-date-picker clearable v-model="formData.birthday" type="date" value-format="timestamp" placeholder="选择出生日期" />
18+
<el-date-picker clearable v-model="formData.birthday" type="date" value-format="timestamp"
19+
placeholder="选择出生日期"/>
1820
</el-form-item>
1921
<el-form-item label="简介">
2022
<Editor v-model="formData.description" :min-height="192"/>
@@ -23,10 +25,10 @@
2325
<!-- 子表的表单 -->
2426
<el-tabs v-model="subTabsName">
2527
<el-tab-pane label="学生课程" name="demo03Course">
26-
<Demo03CourseForm ref="demo03CourseFormRef" :student-id="formData.id" />
28+
<Demo03CourseForm ref="demo03CourseFormRef" :student-id="formData.id"/>
2729
</el-tab-pane>
2830
<el-tab-pane label="学生班级" name="demo03Grade">
29-
<Demo03GradeForm ref="demo03GradeFormRef" :student-id="formData.id" />
31+
<Demo03GradeForm ref="demo03GradeFormRef" :student-id="formData.id"/>
3032
</el-tab-pane>
3133
</el-tabs>
3234
<div slot="footer" class="dialog-footer">
@@ -40,8 +42,9 @@
4042
<script>
4143
import * as Demo03StudentApi from '@/api/infra/demo03-inner';
4244
import Editor from '@/components/Editor';
43-
import Demo03CourseForm from './components/Demo03CourseForm.vue';
44-
import Demo03GradeForm from './components/Demo03GradeForm.vue';
45+
import Demo03CourseForm from './components/Demo03CourseForm.vue'
46+
import Demo03GradeForm from './components/Demo03GradeForm.vue'
47+
4548
export default {
4649
name: "Demo03StudentForm",
4750
components: {

src/views/infra/demo/demo03/inner/components/Demo03CourseForm.vue

Lines changed: 18 additions & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -1,26 +1,26 @@
11
<template>
22
<div class="app-container">
33
<el-form
4-
ref="formRef"
5-
:model="formData"
6-
:rules="formRules"
7-
v-loading="formLoading"
8-
label-width="0px"
9-
:inline-message="true"
4+
ref="formRef"
5+
:model="formData"
6+
:rules="formRules"
7+
v-loading="formLoading"
8+
label-width="0px"
9+
:inline-message="true"
1010
>
1111
<el-table :data="formData" class="-mt-10px">
12-
<el-table-column label="序号" type="index" width="100" />
12+
<el-table-column label="序号" type="index" width="100"/>
1313
<el-table-column label="名字" min-width="150">
1414
<template v-slot="{ row, $index }">
1515
<el-form-item :prop="`${$index}.name`" :rules="formRules.name" class="mb-0px!">
16-
<el-input v-model="row.name" placeholder="请输入名字" />
16+
<el-input v-model="row.name" placeholder="请输入名字"/>
1717
</el-form-item>
1818
</template>
1919
</el-table-column>
2020
<el-table-column label="分数" min-width="150">
2121
<template v-slot="{ row, $index }">
2222
<el-form-item :prop="`${$index}.score`" :rules="formRules.score" class="mb-0px!">
23-
<el-input v-model="row.score" placeholder="请输入分数" />
23+
<el-input v-model="row.score" placeholder="请输入分数"/>
2424
</el-form-item>
2525
</template>
2626
</el-table-column>
@@ -39,11 +39,11 @@
3939

4040
<script>
4141
import * as Demo03StudentApi from '@/api/infra/demo03-inner';
42+
4243
export default {
4344
name: "Demo03CourseForm",
44-
components: {
45-
},
46-
props:[
45+
components: {},
46+
props: [
4747
'studentId'
4848
],// 学生编号(主表的关联字段)
4949
data() {
@@ -60,8 +60,9 @@ export default {
6060
},
6161
};
6262
},
63-
watch:{/** 监听主表的关联字段的变化,加载对应的子表数据 */
64-
studentId:{
63+
watch: {
64+
/** 监听主表的关联字段的变化,加载对应的子表数据 */
65+
studentId: {
6566
handler(val) {
6667
// 1. 重置表单
6768
this.formData = []
@@ -73,7 +74,7 @@ export default {
7374
this.formLoading = true;
7475
// 这里还是需要获取一下 this 的不然取不到 formData
7576
const that = this;
76-
Demo03StudentApi.getDemo03CourseListByStudentId(val).then(function (res){
77+
Demo03StudentApi.getDemo03CourseListByStudentId(val).then(function (res) {
7778
that.formData = res.data;
7879
})
7980
} finally {
@@ -100,11 +101,11 @@ export default {
100101
this.formData.splice(index, 1);
101102
},
102103
/** 表单校验 */
103-
validate(){
104+
validate() {
104105
return this.$refs["formRef"].validate();
105106
},
106107
/** 表单值 */
107-
getData(){
108+
getData() {
108109
return this.formData;
109110
}
110111
}

src/views/infra/demo/demo03/inner/components/Demo03CourseList.vue

Lines changed: 20 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -1,9 +1,14 @@
11
<template>
22
<div class="app-container">
3-
<el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
4-
<el-table-column label="编号" align="center" prop="id" />
5-
<el-table-column label="名字" align="center" prop="name" />
6-
<el-table-column label="分数" align="center" prop="score" />
3+
<el-table
4+
v-loading="loading"
5+
:data="list"
6+
:stripe="true"
7+
:show-overflow-tooltip="true"
8+
>
9+
<el-table-column label="编号" align="center" prop="id"/>
10+
<el-table-column label="名字" align="center" prop="name"/>
11+
<el-table-column label="分数" align="center" prop="score"/>
712
<el-table-column label="创建时间" align="center" prop="createTime" width="180">
813
<template v-slot="scope">
914
<span>{{ parseTime(scope.row.createTime) }}</span>
@@ -12,9 +17,11 @@
1217
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
1318
<template v-slot="scope">
1419
<el-button size="mini" type="text" icon="el-icon-edit" @click="openForm(scope.row.id)"
15-
v-hasPermi="['infra:demo03-student:update']">修改</el-button>
20+
v-hasPermi="['infra:demo03-student:update']">修改
21+
</el-button>
1622
<el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)"
17-
v-hasPermi="['infra:demo03-student:delete']">删除</el-button>
23+
v-hasPermi="['infra:demo03-student:delete']">删除
24+
</el-button>
1825
</template>
1926
</el-table-column>
2027
</el-table>
@@ -23,9 +30,10 @@
2330

2431
<script>
2532
import * as Demo03StudentApi from '@/api/infra/demo03-inner';
33+
2634
export default {
2735
name: "Demo03CourseList",
28-
props:[
36+
props: [
2937
'studentId'
3038
],// 学生编号(主表的关联字段)
3139
data() {
@@ -39,11 +47,12 @@ export default {
3947
created() {
4048
this.getList();
4149
},
42-
watch:{/** 监听主表的关联字段的变化,加载对应的子表数据 */
43-
studentId:{
50+
watch: {
51+
/** 监听主表的关联字段的变化,加载对应的子表数据 */
52+
studentId: {
4453
handler(val) {
4554
this.queryParams.studentId = val;
46-
if (val){
55+
if (val) {
4756
this.handleQuery();
4857
}
4958
},
@@ -61,11 +70,7 @@ export default {
6170
this.loading = false;
6271
}
6372
},
64-
/** 搜索按钮操作 */
65-
handleQuery() {
66-
this.queryParams.pageNo = 1;
67-
this.getList();
68-
},
73+
6974
}
7075
};
7176
</script>

src/views/infra/demo/demo03/inner/components/Demo03GradeForm.vue

Lines changed: 16 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -1,29 +1,29 @@
11
<template>
22
<div class="app-container">
33
<el-form
4-
ref="formRef"
5-
:model="formData"
6-
:rules="formRules"
7-
label-width="100px"
8-
v-loading="formLoading"
4+
ref="formRef"
5+
:model="formData"
6+
:rules="formRules"
7+
label-width="100px"
8+
v-loading="formLoading"
99
>
1010
<el-form-item label="名字" prop="name">
11-
<el-input v-model="formData.name" placeholder="请输入名字" />
11+
<el-input v-model="formData.name" placeholder="请输入名字"/>
1212
</el-form-item>
1313
<el-form-item label="班主任" prop="teacher">
14-
<el-input v-model="formData.teacher" placeholder="请输入班主任" />
14+
<el-input v-model="formData.teacher" placeholder="请输入班主任"/>
1515
</el-form-item>
1616
</el-form>
1717
</div>
1818
</template>
1919

2020
<script>
2121
import * as Demo03StudentApi from '@/api/infra/demo03-inner';
22+
2223
export default {
2324
name: "Demo03GradeForm",
24-
components: {
25-
},
26-
props:[
25+
components: {},
26+
props: [
2727
'studentId'
2828
],// 学生编号(主表的关联字段)
2929
data() {
@@ -40,8 +40,9 @@ export default {
4040
},
4141
};
4242
},
43-
watch:{/** 监听主表的关联字段的变化,加载对应的子表数据 */
44-
studentId:{
43+
watch: {
44+
/** 监听主表的关联字段的变化,加载对应的子表数据 */
45+
studentId: {
4546
handler(val) {
4647
// 1. 重置表单
4748
this.formData = {
@@ -58,7 +59,7 @@ export default {
5859
this.formLoading = true;
5960
// 这里还是需要获取一下 this 的不然取不到 formData
6061
const that = this;
61-
Demo03StudentApi.getDemo03GradeByStudentId(val).then(function (res){
62+
Demo03StudentApi.getDemo03GradeByStudentId(val).then(function (res) {
6263
const data = res.data;
6364
if (!data) {
6465
return
@@ -74,11 +75,11 @@ export default {
7475
},
7576
methods: {
7677
/** 表单校验 */
77-
validate(){
78+
validate() {
7879
return this.$refs["formRef"].validate();
7980
},
8081
/** 表单值 */
81-
getData(){
82+
getData() {
8283
return this.formData;
8384
}
8485
}

0 commit comments

Comments
 (0)