04. 开发课程管理页面
小笔记(源码)
<template>
<div>
<div class="card" style="margin-bottom: 10px;">
<el-input style="width: 300px; margin-right: 10px" placeholder="请输入关键字查询"></el-input>
<el-button type="primary">查询</el-button>
<el-button type="info" style="margin: 0 10px">重置</el-button>
</div>
<div class="card" style="margin-bottom: 10px">
<div style="margin-bottom: 10px">
<el-button type="primary" @click="handleAdd">新增</el-button>
</div>
<el-table stripe :data="data.tableData">
<el-table-column label="名称" prop="name"></el-table-column>
<el-table-column label="描述" prop="descr"></el-table-column>
<el-table-column label="课时" prop="times"></el-table-column>
<el-table-column label="操作" align="center" width="160">
<template v-slot="scope">
<el-button type="primary" @click="handleEdit">编辑</el-button>
<el-button type="danger" @click="handleDelete">删除</el-button>
</template>
</el-table-column>
</el-table>
</div>
<div class="card">
<el-pagination background layout="prev, pager, next" :page-size="8" v-model:current-page="data.pageNum" :total="1000"/>
</div>
<el-dialog title="信息" width="40%" v-model="data.formVisible" :close-on-click-modal="false" destroy-on-close>
<el-form :model="data.form" label-width="100px" style="padding-right: 50px">
<el-form-item label="名称" prop="name">
<el-input v-model="data.form.name" autocomplete="off" />
</el-form-item>
<el-form-item label="描述" prop="descr">
<el-input v-model="data.form.descr" autocomplete="off" />
</el-form-item>
</el-form>
<template #footer>
<span class="dialog-footer">
<el-button @click="data.formVisible = false">取 消</el-button>
<el-button type="primary" @click="data.formVisible = false">保 存</el-button>
</span>
</template>
</el-dialog>
</div>
</template>
<script setup>
import request from "@/utils/request";
import {reactive} from "vue";
import {ElMessageBox} from "element-plus";
request.get('/').then(res => {
console.log(res)
})
const data = reactive({
pageNum: 1,
formVisible: false,
form: {},
tableData: [
{name: '大学英语', descr: '大学英语真有趣', times: '24课时'},
{name: '大学英语', descr: '大学英语真有趣', times: '24课时'},
{name: '大学英语', descr: '大学英语真有趣', times: '24课时'},
{name: '大学英语', descr: '大学英语真有趣', times: '24课时'},
{name: '大学英语', descr: '大学英语真有趣', times: '24课时'},
{name: '大学英语', descr: '大学英语真有趣', times: '24课时'},
{name: '大学英语', descr: '大学英语真有趣', times: '24课时'},
{name: '大学英语', descr: '大学英语真有趣', times: '24课时'},
]
})
const handleAdd = () => {
data.form = {}
data.formVisible = true
}
const handleEdit = (row) => {
let form = JSON.parse(JSON.stringify(row))
data.formVisible = true
}
const handleDelete = (id) => {
ElMessageBox.confirm('删除后数据无法恢复,您确定删除吗?', '删除确认', { type: 'warning' }).then(res => {
console.log('删除')
}).catch(err => {
console.error(err)
})
}
</script>
怎么开发
- 理清楚思路,想想课程有哪些属性(名称、编号、简介、课时、任课老师)
- 设计数据库
- 开发页面
- 开发后台接口
- 前后端数据对接
- 测试
设计数据库
CREATE TABLE `course` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'ID',
`name` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '课程名称',
`no` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '课程编号',
`descr` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '课程描述',
`times` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '课时',
`teacher` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '任课老师',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='课程信息';
页面怎么写
参考官网给的例子
表单
https://element-plus.gitee.io/zh-CN/component/form.html
el-form :model="data.form" label-width="100px">
<el-form-item label="Activity name">
<el-input v-model="form.name" />
</el-form-item>
</el-form>
const data = reactive({
form: {}
})
表格
https://element-plus.gitee.io/zh-CN/component/table.html
<el-table :data="data.tableData" stripe>
<el-table-column prop="name" label="名称" width="180" />
</el-table>
const data = reactive({
tableData: []
})
分页
<el-pagination background layout="prev, pager, next" :total="1000" />
后台接口怎么写
增删改查