| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 |
- <template>
- <div>
- <div class="header-actions">
- <h2>用户管理</h2>
- <el-button type="primary" @click="openDialog()">新增</el-button>
- </div>
- <el-table :data="items" style="width: 100%" v-loading="loading">
- <el-table-column prop="id" label="ID" width="80" />
- <el-table-column prop="username" label="用户名" />
- <el-table-column prop="created_at" label="创建时间" />
- <el-table-column label="操作" width="180">
- <template #default="scope">
- <el-button size="small" @click="openDialog(scope.row)">编辑</el-button>
- <el-button size="small" type="danger" @click="handleDelete(scope.row)" :disabled="scope.row.username === 'admin'">删除</el-button>
- </template>
- </el-table-column>
- </el-table>
- <el-dialog v-model="dialogVisible" :title="isEdit ? '编辑用户' : '新增用户'">
- <el-form :model="form" label-width="120px">
- <el-form-item label="用户名">
- <el-input v-model="form.username" :disabled="isEdit" />
- </el-form-item>
- <el-form-item label="密码">
- <el-input v-model="form.password" type="password" placeholder="如不修改请留空" />
- </el-form-item>
- </el-form>
- <template #footer>
- <span class="dialog-footer">
- <el-button @click="dialogVisible = false">取消</el-button>
- <el-button type="primary" @click="handleSubmit">确定</el-button>
- </span>
- </template>
- </el-dialog>
- </div>
- </template>
- <script setup>
- import { ref, onMounted } from 'vue'
- import api from '../api'
- import { ElMessage, ElMessageBox } from 'element-plus'
- const items = ref([])
- const loading = ref(false)
- const dialogVisible = ref(false)
- const isEdit = ref(false)
- const form = ref({
- id: null,
- username: '',
- password: ''
- })
- const fetchData = async () => {
- loading.value = true
- try {
- const res = await api.get('/users')
- items.value = res.data
- } catch (error) {
- ElMessage.error('获取数据失败')
- } finally {
- loading.value = false
- }
- }
- const openDialog = (item = null) => {
- if (item) {
- isEdit.value = true
- form.value = { ...item, password: '' }
- } else {
- isEdit.value = false
- form.value = { id: null, username: '', password: '' }
- }
- dialogVisible.value = true
- }
- const handleSubmit = async () => {
- try {
- if (isEdit.value) {
- await api.put(`/users/${form.value.id}`, form.value)
- ElMessage.success('更新成功')
- } else {
- await api.post('/users', form.value)
- ElMessage.success('创建成功')
- }
- dialogVisible.value = false
- fetchData()
- } catch (error) {
- ElMessage.error('操作失败')
- }
- }
- const handleDelete = (item) => {
- ElMessageBox.confirm('确定要删除此用户吗?', '警告', {
- confirmButtonText: '是',
- cancelButtonText: '否',
- type: 'warning'
- }).then(async () => {
- try {
- await api.delete(`/users/${item.id}`)
- ElMessage.success('删除成功')
- fetchData()
- } catch (error) {
- ElMessage.error('删除失败')
- }
- })
- }
- onMounted(fetchData)
- </script>
- <style scoped>
- .header-actions {
- display: flex;
- justify-content: space-between;
- align-items: center;
- margin-bottom: 20px;
- }
- </style>
|