Tlias前端
员工管理
条件分页查询:
页面布局
搜索栏:
<!-- 搜索栏 -->
<div class="container">
<el-form :inline="true" :model="searchEmp" class="demo-form-inline">
<el-form-item label="姓名">
<el-input v-model="searchEmp.name" placeholder="请输入员工姓名" />
</el-form-item>
<el-form-item label="性别">
<el-select v-model="searchEmp.gender" placeholder="请选择">
<el-option label="男" value="1" />
<el-option label="女" value="2" />
</el-select>
</el-form-item>
<el-form-item label="入职时间">
<el-date-picker
v-model="searchEmp.date"
type="daterange"
range-separator="到"
start-placeholder="开始日期"
end-placeholder="结束日期" :size="size"
value-format="YYYY-MM-DD"
/>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="search">查询</el-button>
<el-button type="info" @click="clear">清空</el-button>
</el-form-item>
</el-form>
</div>
Watch:
作用:侦听一个或多个响应式数据源,并在数据源变化时调用传入的回调函数。
用法:1.导入Watch函数2.执行watch函数,传入要侦听的响应式数据源(ref对象)和回调函数
单个响应式变量:
侦听对象的全部属性:
第三个可选参数,常见两个选项:
deep(boolean)是否深度侦听,默认浅层侦听。
immediate(boolean)是否在侦听时创建立即触发的回调函数。
侦听对象的单个属性;
import { ref ,watch} from 'vue'
const searchEmp = ref({name: '',gender: '',date: [],begin: '',end: ''})
//侦听searchEmp的date
watch(() => searchEmp.value.date,(newval,oldval) => {
if(searchEmp.value.date.length == 2 ){
searchEmp.value.begin = newval[0]
searchEmp.value.end = newval[1]
}else{
searchEmp.value.begin = ''
searchEmp.value.end = ''
}
})
按钮:
<!-- 按钮 -->
<div class="container">
<el-button type="primary" @click="">+新增员工</el-button>
<el-button type="danger" @click="">-批量删除</el-button>
</div>
数据展示表格:
<div class="container">
<el-table :data="empList" style="width: 100%">
<el-table-column type="selection" width="55" />
<el-table-column prop="name" label="姓名" width="120" align="center" />
<el-table-column label="性别" width="120" align="center">
<template #default="scope">
{{ scope.row.gender == 1 ? '男' : '女' }}
</template>
</el-table-column>
<el-table-column label="头像" align="center" width="180">
<template #default="scope">
<el-image :src="scope.row.image" style="width:40px" />
</template>
</el-table-column>
<el-table-column prop="deptName" label="所属部门" width="120" align="center" />
<el-table-column prop="job" label="职位" width="120" align="center">
<template #default="scope">
<span v-if="scope.row.job == 1">班主任</span>
<span v-else-if="scope.row.job == 2">讲师</span>
<span v-else-if="scope.row.job == 3">学工主管</span>
<span v-else-if="scope.row.job == 4">教研主管</span>
<span v-else-if="scope.row.job == 5">咨询师</span>
<span v-else>其他</span>
</template>
</el-table-column>
<el-table-column prop="entryDate" label="入职日期" width="180" align="center" />
<el-table-column prop="updateTime" label="最后操作时间" width="180" align="center" />
<!-- 操作 -->
<el-table-column label="操作" width="180" align="center">
<template #default="scope">
<el-button type="primary" size="small" @click=""><el-icon>
<EditPen />
</el-icon>编辑</el-button>
<el-button type="danger" size="small" @click=""><el-icon>
<Delete />
</el-icon>删除</el-button>
</template>
</el-table-column>
</el-table>
</div>
分页条:
//定义员工列表
const empList = ref([])
//分页
const currentPage = ref(1)//当前页
const pageSize = ref(10)//每页显示多少条
const background = ref(true)
const total = ref(0)
// 查询
const search = async () => {
const res = await queryPageApi(searchEmp.value.name, searchEmp.value.gender,
searchEmp.value.begin, searchEmp.value.end, currentPage.value, pageSize.value)
if(res.code){
empList.value = res.data.rows
total.value = res.data.total
}
}
//每页展示记录数变化时
const handleSizeChange = (val) => {
search()
}
//当前页变化时
const handleCurrentChange = (val) => {
search()
}
<!-- 分页条 -->
<div class="container">
<el-pagination
v-model:current-page="currentPage"
v-model:page-size="pageSize"
:page-sizes="[5, 10, 15, 20, 25, 30, 35, 40]"
:background="background"
layout="total, sizes, prev, pager, next, jumper"
:total="total"
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
/>
</div>
页面交互:
1.页面加载完毕后,查询员工信息列表
2.点击查询按钮,查询员工信息列表
3.当页码、每页展示记录数发生变化时,查询员工信息列表
新增员工:
新增员工信息的表单包含两个部分:
员工的基本信息
员工的工作经历信息
新增/修改员工的对话框:
1.表单项数据动态展示:
性别(男/女) 职位(班主任/讲师/学工主管/教研主管/) 所属部门(动态查询)
2.工作经历:
添加工作经历:下方就会增加一个工作经历信息
删除工作经历:删除当前这一个工作经历信息
(Vue是基于数据驱动视图展示的)
<!-- 新增/修改员工的对话框 -->
<el-dialog v-model="dialogVisible" :title="dialogTitle">
{{ employee }}
<el-form ref="employeeFormRef" :model="employee" label-width="80px">
<!-- 基本信息 -->
<!-- 第一行 -->
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="用户名">
<el-input v-model="employee.username" placeholder="请输入员工用户名,2-20个字"></el-input>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="姓名">
<el-input v-model="employee.name" placeholder="请输入员工姓名,2-10个字"></el-input>
</el-form-item>
</el-col>
</el-row>
<!-- 第二行 -->
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="性别">
<el-select v-model="employee.gender" placeholder="请选择性别" style="width: 100%;">
<el-option v-for="g in genders" :label="g.name" :value="g.value"></el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="手机号">
<el-input v-model="employee.phone" placeholder="请输入员工手机号"></el-input>
</el-form-item>
</el-col>
</el-row>
<!-- 第三行 -->
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="职位">
<el-select v-model="employee.job" placeholder="请选择职位" style="width: 100%;">
<el-option v-for="j in jobs" :label="j.name" :value="j.value"></el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="薪资">
<el-input v-model="employee.salary" placeholder="请输入员工薪资"></el-input>
</el-form-item>
</el-col>
</el-row>
<!-- 第四行 -->
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="所属部门">
<el-select v-model="employee.deptId" placeholder="请选择部门" style="width: 100%;">
<el-option v-for="d in deptList" :label="d.name" :key="d.id" :value="d.id"></el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="入职日期">
<el-date-picker v-model="employee.entryDate" type="date" style="width: 100%;" placeholder="选择日期"
format="YYYY-MM-DD" value-format="YYYY-MM-DD"></el-date-picker>
</el-form-item>
</el-col>
</el-row>
<!-- 第五行 -->
<el-row :gutter="20">
<el-col :span="24">
<el-form-item label="头像">
<el-upload class="avatar-uploader" action="/api/upload" :show-file-list="false"
:on-success="handleAvatarSuccess" :before-upload="beforeAvatarUpload">
<img v-if="employee.image" :src="employee.image" class="avatar" />
<el-icon v-else class="avatar-uploader-icon">
<Plus />
</el-icon>
</el-upload>
</el-form-item>
</el-col>
</el-row>
<!-- 工作经历 -->
<!-- 第六行 -->
<el-row :gutter="10">
<el-col :span="24">
<el-form-item label="工作经历">
<el-button type="success" size="small" @click="addExpr">+ 添加工作经历</el-button>
</el-form-item>
</el-col>
</el-row>
<!-- 第七行 ... 工作经历 -->
<el-row :gutter="3" v-for="(expr, index) in employee.exprList">
<el-col :span="10">
<el-form-item size="small" v-model="expr.value.exprDate" label="时间" label-width="80px">
<el-date-picker type="daterange" range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期"
format="YYYY-MM-DD" value-format="YYYY-MM-DD"></el-date-picker>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item size="small" v-model="expr.company" label="公司" label-width="60px">
<el-input placeholder="请输入公司名称"></el-input>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item size="small" v-model="expr.job" label="职位" label-width="60px">
<el-input placeholder="请输入职位"></el-input>
</el-form-item>
</el-col>
<el-col :span="2">
<el-form-item size="small" label-width="0px">
<el-button type="danger" @click="deleteExpr(index)">- 删除</el-button>
</el-form-item>
</el-col>
</el-row>
</el-form>
<!-- 底部按钮 -->
<template #footer>
<span class="dialog-footer">
<el-button @click="dialogVisible = false">取消</el-button>
<el-button type="primary" @click="">保存</el-button>
</span>
</template>
</el-dialog>
保存:
1.点击保存之后,发送异步请求到服务器,提交数据。
2.保存完毕后,如果成功,关闭对话框,重新加载列表数据。
3.保存完毕后,如果失败,提示错误信息。
修改员工:
查询回显:
为编辑按钮绑定事件,发送异步请求,根据ID查询员工详细信息,页面回显
//编辑员工信息
const editEmp = async (id) => {
const result = await queryEmpByIdApi(id)
if (result.code) {
dialogVisible.value = true
dialogTitle.value = '修改员工'
employee.value = result.data
} else {
ElMessage.error(result.msg)
}
//对工作经历数据进行处理
let exprList = employee.value.exprList
//判断exprList是否有值和长度大于0
if (exprList && exprList.length > 0) {
exprList.forEach((expr) => {
expr.exprDate = [expr.begin, expr.end]
})
}
}
保存数据:
点击保存按钮,执行修改数据操作,备注:添加员工和修改员工使用的是同一个表单,需要根据id判断到底是执行新增还是修改。
//保存员工信息
const save = async () => {
if (!employeeFormRef.value) {
return
}
employeeFormRef.value.validate(async valid => {
if (valid) { // 校验通过
let result;
if (employee.value.id) {
result = await editEmpApi(employee.value)
} else {
result = await addEmpApi(employee.value)
}
if (result.code) {
ElMessage.success('保存成功')
dialogVisible.value = false
search()
} else {
ElMessage.error(result.msg)
}
} else {
ElMessage.error('表单校验失败')
}
}
)
}
删除员工:
在删除员工信息时,有两个操作路口:
1.点击每条记录之后的“删除”按钮,删除当前这条记录
为“删除”按钮添加绑定事件,触发事件,调用函数,发送异步请求到服务端,根据id删除员工信息
//删除员工信息
const deleteById = async (id) => {
ElMessageBox.confirm('你确定要删除该员工吗?', '提示',
{ confirmButtonText: '确定', cancelButtonText: '取消', type: 'warning', }
).then(async () => {
const result = await deleteEmpApi(id)
if (result.code) {
ElMessage.success('删除成功');
search();
} else {
ElMessage.error(result.msg);
}
}).catch(() => {
ElMessage.info('已取消删除')
})
}
2.选择前面的复选框,选中要删除的员工,点击“批量删除”之后,会批量删除员工信息
为表格的复选框绑定事件,点击复选框之后,获取到目前选中的条件的id(多个id可以封装到数组中),为“批量删除”按钮绑定事件,发送异步请求到服务端,根据id批量删除员工信息。
//批量删除勾选的员工信息
const selectedIds = ref([])
//多选框选中时触发
const handleSelectionChange = (selection) => {
selectedIds.value = selection.map(item => item.id)
}
//批量删除员工信息
const deleteBatch = () => {
ElMessageBox.confirm('你确定要批量删除这些员工吗?', '提示',
{ confirmButtonText: '确定', cancelButtonText: '取消', type: 'warning', }
).then(async () => {
if (selectedIds.value && selectedIds.value.length > 0) {
const result = await deleteEmpApi(selectedIds.value)
if (result.code) {
ElMessage.success('删除成功');
search();
} else {
ElMessage.error(result.msg);
}
} else {
ElMessage.error('您没有选择要删除的员工')
}
}).catch(() => {
ElMessage.info('已取消删除')
})
}
完整Vue代码:
<script setup>
import { Delete } from '@element-plus/icons-vue'
import { ref, watch, onMounted } from 'vue'
import { queryPageApi, addEmpApi, editEmpApi, queryEmpByIdApi, deleteEmpApi } from '@/api/emp'
import { ElMessage, ElMessageBox } from 'element-plus'
import { queryAllApi as queryAllDeptApi } from '@/api/dept'
//职位列表数据
const jobs = ref([{ name: '班主任', value: 1 }, { name: '讲师', value: 2 }, { name: '学工主管', value: 3 }, { name: '教研主管', value: 4 }, { name: '咨询师', value: 5 }, { name: '其他', value: 6 }])
//性别列表数据
const genders = ref([{ name: '男', value: 1 }, { name: '女', value: 2 }])
//部门列表数据
const deptList = ref([])
//定义钩子
onMounted(() => {
search()//查询员工列表
queryAllDept()//查询部门列表
})
//查询部门列表
const queryAllDept = async () => {
const res = await queryAllDeptApi()
if (res.code) {
deptList.value = res.data
}
}
//定义搜索条件
const searchEmp = ref({ name: '', gender: '', date: [], begin: '', end: '' })
//侦听searchEmp的date
watch(() => searchEmp.value.date, (newval, oldval) => {
if (searchEmp.value.date.length == 2) {
searchEmp.value.begin = newval[0]
searchEmp.value.end = newval[1]
} else {
searchEmp.value.begin = ''
searchEmp.value.end = ''
}
})
// 清空
const clear = () => {
searchEmp.value = { name: '', gender: '', date: [] }
search()
}
//定义员工列表
const empList = ref([])
//分页
const currentPage = ref(1)//当前页
const pageSize = ref(10)//每页显示多少条
const background = ref(true)
const total = ref(0)
// 查询
const search = async () => {
const res = await queryPageApi(searchEmp.value.name, searchEmp.value.gender,
searchEmp.value.begin, searchEmp.value.end, currentPage.value, pageSize.value)
if (res.code) {
empList.value = res.data.rows
total.value = res.data.total
}
}
//每页展示记录数变化时
const handleSizeChange = (val) => {
search()
}
//当前页变化时
const handleCurrentChange = (val) => {
search()
}
//新增员工
const addEmp = () => {
dialogVisible.value = true
dialogTitle.value = '新增员工'
employee.value = {
username: '',
name: '',
gender: '',
phone: '',
job: '',
salary: '',
deptId: '',
entryDate: '',
image: '',
exprList: []
}
//清空表单校验
if (employeeFormRef.value) {
employeeFormRef.value.resetFields()
}
}
//新增/修改表单
const employeeFormRef = ref(null)
const employee = ref({
username: '',
name: '',
gender: '',
phone: '',
job: '',
salary: '',
deptId: '',
entryDate: '',
image: '',
exprList: []
})
// 控制弹窗
const dialogVisible = ref(false)
const dialogTitle = ref('新增员工')
//文件上传
// 图片上传成功后触发
const handleAvatarSuccess = (response, uploadFile) => {
employee.value.image = response.data
}
// 文件上传之前触发
const beforeAvatarUpload = (rawFile) => {
if (rawFile.type !== 'image/jpeg' && rawFile.type !== 'image/png') {
ElMessage.error('只支持上传图片')
return false
} else if (rawFile.size / 1024 / 1024 > 10) {
ElMessage.error('只能上传10M以内图片')
return false
}
return true
}
//添加工作经历
const addExpr = () => {
employee.value.exprList.push({
company: '',
job: '',
begin: '',
end: '',
exprDate: []
})
}
//删除工作经历
const deleteExpr = (index) => {
employee.value.exprList.splice(index, 1)
}
//侦听exprList
watch(() => employee.value.exprList, (newValue, oldValue) => {
if (employee.value.exprList && employee.value.exprList.length > 0) {
employee.value.exprList.forEach(expr => {
expr.begin = expr.exprDate[0]
expr.end = expr.exprDate[1]
})
}
}, { deep: true });
//保存
//保存员工信息
const save = async () => {
if (!employeeFormRef.value) {
return
}
employeeFormRef.value.validate(async valid => {
if (valid) { // 校验通过
let result;
if (employee.value.id) {
result = await editEmpApi(employee.value)
} else {
result = await addEmpApi(employee.value)
}
if (result.code) {
ElMessage.success('保存成功')
dialogVisible.value = false
search()
} else {
ElMessage.error(result.msg)
}
} else {
ElMessage.error('表单校验失败')
}
}
)
}
// 验证规则
const rules = ref({
username: [
{ required: true, message: '请输入用户名', trigger: 'blur' },
{ min: 2, max: 20, message: '用户名长度应在2到20个字符之间', trigger: 'blur' }
],
name: [
{ required: true, message: '请输入姓名', trigger: 'blur' },
{ min: 2, max: 10, message: '姓名长度应在2到10个字符之间', trigger: 'blur' }
],
gender: [
{ required: true, message: '请选择性别', trigger: 'change' }
],
phone: [
{ required: true, message: '请输入手机号', trigger: 'blur' },
{ pattern: /^1\d{10}$/g, message: '请输入有效的手机号', trigger: 'blur' }
]
});
//编辑员工信息
const editEmp = async (id) => {
const result = await queryEmpByIdApi(id)
if (result.code) {
dialogVisible.value = true
dialogTitle.value = '修改员工'
employee.value = result.data
} else {
ElMessage.error(result.msg)
}
//对工作经历数据进行处理
let exprList = employee.value.exprList
//判断exprList是否有值和长度大于0
if (exprList && exprList.length > 0) {
exprList.forEach((expr) => {
expr.exprDate = [expr.begin, expr.end]
})
}
}
//删除员工信息
const deleteById = async (id) => {
ElMessageBox.confirm('你确定要删除该员工吗?', '提示',
{ confirmButtonText: '确定', cancelButtonText: '取消', type: 'warning', }
).then(async () => {
const result = await deleteEmpApi(id)
if (result.code) {
ElMessage.success('删除成功');
search();
} else {
ElMessage.error(result.msg);
}
}).catch(() => {
ElMessage.info('已取消删除')
})
}
//批量删除勾选的员工信息
const selectedIds = ref([])
//多选框选中时触发
const handleSelectionChange = (selection) => {
selectedIds.value = selection.map(item => item.id)
}
//批量删除员工信息
const deleteBatch = () => {
ElMessageBox.confirm('你确定要批量删除这些员工吗?', '提示',
{ confirmButtonText: '确定', cancelButtonText: '取消', type: 'warning', }
).then(async () => {
if (selectedIds.value && selectedIds.value.length > 0) {
const result = await deleteEmpApi(selectedIds.value)
if (result.code) {
ElMessage.success('删除成功');
search();
} else {
ElMessage.error(result.msg);
}
} else {
ElMessage.error('您没有选择要删除的员工')
}
}).catch(() => {
ElMessage.info('已取消删除')
})
}
</script>
<template>
<h1>员工管理</h1>
<!-- 搜索栏 -->
<div class="container">
<el-form :inline="true" :model="searchEmp" class="demo-form-inline">
<el-form-item label="姓名">
<el-input v-model="searchEmp.name" placeholder="请输入员工姓名" />
</el-form-item>
<el-form-item label="性别">
<el-select v-model="searchEmp.gender" placeholder="请选择">
<el-option label="男" value="1" />
<el-option label="女" value="2" />
</el-select>
</el-form-item>
<el-form-item label="入职时间">
<el-date-picker v-model="searchEmp.date" type="daterange" range-separator="到" start-placeholder="开始日期"
end-placeholder="结束日期" :size="size" value-format="YYYY-MM-DD" />
</el-form-item>
<el-form-item>
<el-button type="primary" @click="search">查询</el-button>
<el-button type="info" @click="clear">清空</el-button>
</el-form-item>
</el-form>
</div>
<!-- 按钮 -->
<div class="container">
<el-button type="primary" @click="addEmp">+新增员工</el-button>
<el-button type="danger" @click="deleteBatch">-批量删除</el-button>
</div>
<!-- 表格 -->
<div class="container">
<el-table :data="empList" style="width: 100%" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" />
<el-table-column prop="name" label="姓名" width="120" align="center" />
<el-table-column label="性别" width="120" align="center">
<template #default="scope">
{{ scope.row.gender == 1 ? '男' : '女' }}
</template>
</el-table-column>
<el-table-column label="头像" align="center" width="180">
<template #default="scope">
<el-image :src="scope.row.image" style="width:40px" />
</template>
</el-table-column>
<el-table-column prop="deptName" label="所属部门" width="120" align="center" />
<el-table-column prop="job" label="职位" width="120" align="center">
<template #default="scope">
<span v-if="scope.row.job == 1">班主任</span>
<span v-else-if="scope.row.job == 2">讲师</span>
<span v-else-if="scope.row.job == 3">学工主管</span>
<span v-else-if="scope.row.job == 4">教研主管</span>
<span v-else-if="scope.row.job == 5">咨询师</span>
<span v-else>其他</span>
</template>
</el-table-column>
<el-table-column prop="entryDate" label="入职日期" width="180" align="center" />
<el-table-column prop="updateTime" label="最后操作时间" width="180" align="center" />
<!-- 操作 -->
<el-table-column label="操作" width="180" align="center">
<template #default="scope">
<el-button type="primary" size="small" @click="editEmp(scope.row.id)"><el-icon>
<EditPen />
</el-icon>编辑</el-button>
<el-button type="danger" size="small" @click="deleteById(scope.row.id)"><el-icon>
<Delete />
</el-icon>删除</el-button>
</template>
</el-table-column>
</el-table>
</div>
<!-- 分页条 -->
<div class="container">
<el-pagination v-model:current-page="currentPage" v-model:page-size="pageSize"
:page-sizes="[5, 10, 15, 20, 25, 30, 35, 40]" :background="background"
layout="total, sizes, prev, pager, next, jumper" :total="total" @size-change="handleSizeChange"
@current-change="handleCurrentChange" />
</div>
<!-- 新增/修改员工的对话框 -->
<el-dialog v-model="dialogVisible" :title="dialogTitle">
<el-form ref="employeeFormRef" :model="employee" label-width="80px" :rules="rules">
<!-- 基本信息 -->
<!-- 第一行 -->
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="用户名" prop="username">
<el-input v-model="employee.username" placeholder="请输入员工用户名,2-20个字"></el-input>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="姓名" prop="name">
<el-input v-model="employee.name" placeholder="请输入员工姓名,2-10个字"></el-input>
</el-form-item>
</el-col>
</el-row>
<!-- 第二行 -->
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="性别" prop="gender">
<el-select v-model="employee.gender" placeholder="请选择性别" style="width: 100%;">
<el-option v-for="g in genders" :label="g.name" :value="g.value"></el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="手机号" prop="phone">
<el-input v-model="employee.phone" placeholder="请输入员工手机号"></el-input>
</el-form-item>
</el-col>
</el-row>
<!-- 第三行 -->
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="职位">
<el-select v-model="employee.job" placeholder="请选择职位" style="width: 100%;">
<el-option v-for="j in jobs" :label="j.name" :value="j.value"></el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="薪资">
<el-input v-model="employee.salary" placeholder="请输入员工薪资"></el-input>
</el-form-item>
</el-col>
</el-row>
<!-- 第四行 -->
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="所属部门">
<el-select v-model="employee.deptId" placeholder="请选择部门" style="width: 100%;">
<el-option v-for="d in deptList" :label="d.name" :key="d.id" :value="d.id"></el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="入职日期">
<el-date-picker v-model="employee.entryDate" type="date" style="width: 100%;" placeholder="选择日期"
format="YYYY-MM-DD" value-format="YYYY-MM-DD"></el-date-picker>
</el-form-item>
</el-col>
</el-row>
<!-- 第五行 -->
<el-row :gutter="20">
<el-col :span="24">
<el-form-item label="头像">
<el-upload class="avatar-uploader" action="/api/upload" :show-file-list="false"
:on-success="handleAvatarSuccess" :before-upload="beforeAvatarUpload">
<img v-if="employee.image" :src="employee.image" class="avatar" />
<el-icon v-else class="avatar-uploader-icon">
<Plus />
</el-icon>
</el-upload>
</el-form-item>
</el-col>
</el-row>
<!-- 工作经历 -->
<!-- 第六行 -->
<el-row :gutter="10">
<el-col :span="24">
<el-form-item label="工作经历">
<el-button type="success" size="small" @click="addExpr">+ 添加工作经历</el-button>
</el-form-item>
</el-col>
</el-row>
<!-- 第七行 ... 工作经历 -->
<el-row :gutter="3" v-for="(expr, index) in employee.exprList">
<el-col :span="10">
<el-form-item size="small" label="时间" label-width="80px">
<el-date-picker v-model="expr.exprDate" type="daterange" range-separator="至" start-placeholder="开始日期"
end-placeholder="结束日期" format="YYYY-MM-DD" value-format="YYYY-MM-DD"></el-date-picker>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item size="small" label="公司" label-width="60px">
<el-input v-model="expr.company" placeholder="请输入公司名称"></el-input>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item size="small" label="职位" label-width="60px">
<el-input v-model="expr.job" placeholder="请输入职位"></el-input>
</el-form-item>
</el-col>
<el-col :span="2">
<el-form-item size="small" label-width="0px">
<el-button type="danger" @click="deleteExpr(index)">- 删除</el-button>
</el-form-item>
</el-col>
</el-row>
</el-form>
<!-- 底部按钮 -->
<template #footer>
<span class="dialog-footer">
<el-button @click="dialogVisible = false">取消</el-button>
<el-button type="primary" @click="save">保存</el-button>
</span>
</template>
</el-dialog>
</template>
<style scoped>
.container {
margin: 15px 0px;
width: 100%;
}
.avatar {
height: 40px;
}
.avatar-uploader .avatar {
width: 78px;
height: 78px;
display: block;
}
.avatar-uploader .el-upload {
border: 1px dashed var(--el-border-color);
border-radius: 6px;
cursor: pointer;
position: relative;
overflow: hidden;
transition: var(--el-transition-duration-fast);
}
.avatar-uploader .el-upload:hover {
border-color: var(--el-color-primary);
}
.el-icon.avatar-uploader-icon {
font-size: 28px;
color: #8c939d;
width: 78px;
height: 78px;
text-align: center;
/* 添加灰色的虚线边框 */
border: 1px dashed var(--el-border-color);
}
</style>