Day06-角色管理-员工管理

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 1.编辑角色-进入行内编辑
  • 2.角色管理-行内编辑-数据缓存
  • 3.角色管理-编辑角色-确定取消
  • 4.角色管理-删除角色
  • 员工管理-页面结构
  • 6.员工管理-左侧树
  • 7.员工管理-选中首个节点
  • 8.员工管理-员工列表结构
  • 9.员工管理-获取员工数据
  • 10.员工管理-头像和聘用形式的处理
  • 11.员工管理-员工分页处理
  • 12.员工管理-员工模糊搜索


1.编辑角色-进入行内编辑

在这里插入图片描述
在这里插入图片描述

  • 获取数据之后针对每个数据定义标识-使用$set-代码位置(src/views/role/index.vue)
 // 针对每一行数据添加一个编辑标记this.list.forEach(item => {// item.isEdit = false // 添加一个属性 初始值为false// 数据响应式的问题  数据变化 视图更新// 添加的动态属性 不具备响应式特点// this.$set(目标对象, 属性名称, 初始值) 可以针对目标对象 添加的属性 添加响应式this.$set(item, 'isEdit', false)})
  • 点击编辑时,将当前行的标记isEdit设置为true(src/views/role/index.vue)
<el-table-column align="center" label="操作"><template><!-- 非编辑状态 --><el-button size="mini" type="text">分配权限</el-button><el-button size="mini" type="text" @click="btnEditRow(row)">编辑</el-button><el-button size="mini" type="text">删除</el-button></template>
</el-table-column>
  • 点击编辑的方法-
data(){return{row:[] }
}
methods:{btnEditRow(row){row.isEdit = true//改变行的编辑状态
}
}
  • 表格列中根据当前的isEdit标记-渲染结构
<el-table-column prop="name" align="center" width="200" label="角色"><template v-slot="{row}"><el-input v-if="row.isEdit" size="mini"></el-input> <span v-else>{{row.name}}</span></template>
</el-table-column>
<el-table-column prop="state" align="center" width="200" label="启用"><template v-slot="{row}"><el-switch v-if="row.isEdit"/><span v-else>{{row.state === 1? '已启用':row.state === 0 ? "未启用" :"无"}}</span></template>
</el-table-column>
<el-table-column align="center"  label="操作"><template v-slot="{row}"><template v-if="row.isEdit"><el-button type="primary" size="mini" >确定</el-button><el-button  size="mini" >取消</el-button></template><template v-else><el-button size="mini" type="text">分配权限</el-button><el-button size="mini" type="text" @click="btnEditRow(row)">编辑</el-button><el-button size="mini" type="text">取消</el-button></template><span v-else>{{row.name}}</span></template>
</el-table-column>
  • $set的应用
  • this.$set(目标对象,属性名称,初始值)
  • 等价于Vue.set(目标对象,属性名称,初始值)
  • 往响应式对象中添加一个属性,并确保这个新属性同样是响应式的,且触发视图更新。

2.角色管理-行内编辑-数据缓存

  • 原因
  • 因为编辑时,可以取消回滚到之前的状态,所以编辑时的数据是临时的数据

在这里插入图片描述

  • editRow的数据是针对当前行的数据做了一份拷贝,针对这个拷贝,可以修改
  • 初始化时缓存数据(src/views/role/index.vue)
 this.list.forEach(item => {// item.isEdit = false//添加一个属性,初始值为false// 数据响应式问题 数据变化 视图更新// 添加的动态属性 不具备响应式特点// this.$set(目标对象,属性名称,初始值) 可以针对目标对象 添加的属性 添加响应式this.$set(item, 'isEdit', false)this.$set(item,'editRow',{name:item.name,state:item.state,description:item.description})console.log(item['isEdit']);})
  • 点击编辑时更新缓存数据-代码位置(src/views/role/index.vue)
btnEditRow(row) {row.isEdit = true // 改变行的编辑状态// 更新缓存数据row.editRow.name = row.namerow.editRow.state = row.staterow.editRow.description = row.description
}
  • 将编辑时的表单双向绑定缓存数据-代码位置(src/views/role/index.vue)
 <el-table :data="list"><!-- 列 --><el-table-column prop="name" align="center" width="200" label="角色"><template v-slot="{row}"><!-- 条件判断 --><el-input v-if="row.isEdit" v-model="row.editRow.name" size="mini"></el-input><span v-else>{{ row.name }}</span></template></el-table-column><el-table-column prop="state" align="center" width="200" label="启用"><!-- 自定义列结构 --><template v-slot="{row}"><!-- 开 1 关0 --><el-switch v-if="row.isEdit" v-model="row.editRow.state" :active-value="1" :inactive-value="0"></el-switch><span v-else>{{ row.state === 1 ?'已启用':row.state === 0 ?"未启用":'无' }}</span></template></el-table-column><el-table-column prop="description" align="center" label="描述"><template v-solt="{row}"><el-input v-if="row.isEdit" v-model="row.editRow.description" type="textarea"></el-input><span v-else>{{ row.description }}</span></template></el-table-column>><el-table-column align="center" label="操作"><!-- 操作按钮 --><template v-slot="{row}"><template v-if="row.isEdit"><!-- 编辑状态 --><el-button type="primary" size="mini">确定</el-button><el-button size="mini">取消</el-button></template><template v-else><!-- 非编辑状态 --><el-button size="mini" type="text">分配权限</el-button><el-button size="mini" @click="btnEditRow(row)" type="text">编辑</el-button><el-button size="mini" type="text">删除</el-button></template></template></el-table-column></el-table>

3.角色管理-编辑角色-确定取消

在这里插入图片描述

  • 更新角色信息的请求api(src/api/role.js)
export function updateRole(data){return request({url:`/sys/role/${data.id}`,method:'put',data })
}
  • 确定方法
 <!-- 编辑状态 --><el-button type="primary" size="mini" @click="btnEditOK(row)">确定</el-button><el-button size="mini">取消</el-button>
 async btnEditOK(row) {if (row.editRow.name && row.editRow.description) {//下一步操作 调用更新请求接口const result = await updateRole({ ...row.editRow,id: row.id })//更新成功提示this.$message.success('更新角色成功')//更新显式数据 退出编辑状态//row.name = row.editRow.name//eslint的校验 误判//Object.assign(target,source)Object.assign(row, {...row.editRow,isEdit: false//退出编辑模式})//规避eslint的误判}else{this.$message.warning('角色和描述不能为空')}}
  • 更新成功,要把缓存数据回显到页面上,并且关闭编辑模式
  • 取消方法
<el-button size="mini" @click="row.isEdit = false">取消</el-button>

4.角色管理-删除角色

在这里插入图片描述

  • 删除角色的api(src/api/role.js)
export function delRole(id){return request({url:`/sys/role/${id}`,method:'delte' })
}
  • 在删除位置加入气泡框-代码位置(src/views/role/index.vue)
  <!-- 非编辑状态 --><el-button size="mini" type="text">分配权限</el-button><el-button size="mini" @click="btnEditRow(row)" type="text">编辑</el-button><el-popconfirm trigger="hover"title="确定删除吗?"@onConfirm="confirmDel(row.id)"><el-buttonslot="reference" style="margin-left: 10px"size="mini"  type="text">删除</el-button></el-popconfirm>
  • 删除方法-代码位置(src/views/role/index.vue)
async confirmDel(id){await delRole(id)//后端删除this.$message.success('删除成功')//如果删除的是最后一个if(this.list.length === 1){return this.pageParams.page--this.getRoleList()}
}

员工管理-页面结构

在这里插入图片描述
在这里插入图片描述

  • 基本的页面结构-代码位置(src/views/employee/index.vue)
 <div class="app-container"><div class="left"><el-input> </el-input><!-- 树形组件 --></div><div class="right"><el-row class="opeate-tools" type="flex" justify="end"><el-button type="primary" size="mini">添加员工</el-button><el-button size="mini">excel导入</el-button><el-button size="mini">excel导出</el-button></el-row><!-- 表格组件 --><!-- 分页 --></div></div><style scoped lang="scss">
.app-container {background: #fff;display: flex;.left {width: 280px;padding: 20px;border-right: solid 1px #eaee64;}.right {flex: 1;padding: 20px;.opeate-tools {margin: 10px;}.username {height: 30px;width: 30px;line-height: 30px;text-align: center;border-radius: 50%;color: #fff;background: #04c9be;font-size: 12px;display: inline-block;}}
}
</style>

6.员工管理-左侧树

在这里插入图片描述

  • 树组件需要的数据-代码位置(src/views/employee/index.vue)
 data() {return {depts:[],//组织数据defaultProps:{label:'name',children:'children'}};},
  • 树形组件-代码位置(src/views/employee/index.vue)
<el-input> </el-input><!-- 树形组件 --><el-tree :data="depts" :props="defaultProps" default-expand-all expand-on-click-node="false" highlight-current></el-tree>
  • 初始化时加载数据转化树形-(src/views/employee/index.vue)
 methods: {async getDepartment() {//递归将列表转化成树const result = this.getDepartment();console.log(result);this.depts = transListToTreeData(await getDepartment(), 0);},},

7.员工管理-选中首个节点

在这里插入图片描述

  • 在data中声明一个记录id的参数-代码位置(src/views/employee/index.vue)
data(){return{//存查询参数queryParams:{departmentId:null}}
}
  • 因为后面的查询会有很多查询条件,到时候查询条件都会聚合到一起,所以使用一个公共的对象来管理更方便和合适
  • 初始化时首个id节点,并且选中-代码位置(src/views/employee/index.vue)
data () {return  {// 存储查询参数queryParams: {departmentId: null}}
}
  • 初始化时首个id节点,并且选中-代码位置(src/views/employee/index.vue)
methods:{async getDepartment(){this.depts = transListToTreeData(await getDepartment(),0)this.queryParams.departmentId = this.depts[0].idthis.$nextTick(()=>{this.$refs.deptTree.setCurrentKey(this.queryParams.departmentId)})}
}

-监听树组件的节点切换事件-代码位置(src/views/employee/index.vue)

   <el-tree ref="deptTree":data="depts":props="defaultProps"default-expand-allexpand-on-click-node="false"highlight-current@current-change="selectNode"></el-tree>
  • 里需要明白,需要给定node-key属性,否则setCurrentKey方法不知道设置的是哪个字段的值
  • 切换节点时再次记录id-代码位置(src/views/employee/index.vue)
 selectNode(node){this.queryParams.departmentId = node.id}

8.员工管理-员工列表结构

  • 右侧列表页面结构-代码位置(src/views/employee/index.vue)
<el-table><el-table-column align="center" label="头像" /><el-table-column label="姓名" /><el-table-column label="手机号" sortable /><el-table-column label="工号" sortable /><el-table-column label="聘用形式" /><el-table-column label="部门" /><el-table-column label="入职时间" sortable /><el-table-column label="操作" width="280px"><template><el-button size="mini" type="text">查看</el-button><el-button size="mini" type="text">角色</el-button><el-button size="mini" type="text">删除</el-button></template></el-table-column>
</el-table>
<!-- 分页 -->
<el-row style="height: 60px" align="middle" type="flex" justify="end"><el-paginationlayout="total,prev, pager, next":total="1000"/>
</el-row>

9.员工管理-获取员工数据

在这里插入图片描述

  • 获取员工数据的API-代码位置(src/api/employee.js)
export function getEmployeeList(params) {return request({url: '/sys/user',params // 地址参数 查询参数})
}
  • 声明一个list数据进行接受list-代码位置(src/views/employee/index.vue)
data () {return {list: []}
}
  • 初始化后获取右侧表格数据-代码位置(src/views/employee/index.vue)
methods: {async getDepartment() {// 递归方法 将列表转化成树形// let result = await getDepartment()this.depts = transListToTreeData(await getDepartment(), 0)this.queryParams.departmentId = this.depts[0].id// 设置选中节点// 树组件渲染是异步的 等到更新完毕this.$nextTick(() => {// 此时意味着树渲染完毕this.$refs.deptTree.setCurrentKey(this.queryParams.departmentId)})// 这个时候参数 记录了idthis.getEmployeeList()},// 获取员工列表的方法async getEmployeeList() {const { rows } = await getEmployeeList(this.queryParams)this.list = rows}}
  • 切换节点时,获取右侧表格数据-代码位置(src/views/employee/index.vue)
 async getDepartment() {//递归将列表转化成树const result = this.getDepartment();console.log(result);this.depts = transListToTreeData(await getDepartment(), 0);this.queryParams.departmentId = this.depts[0].id//设置选中节点//树组件渲染是异步的 等到更新完毕this.$nextTick(() => {this.$refs.deptTree.setCurrentKey(this.queryParams.departmentId)})//this.getEmployeeList()},selectNode(node) {this.queryParams.departmentId = node.id //重新记录参数this.getEmployeeList()},//获取员工列表async getEmployeeList(){const { rows } = await getEmployeeList(this.queryParams)this.list = rows;}
  • 绑定表格-代码位置(src/views/employee/index.vue)
<el-table :data="list"><el-table-column prop="staffPhoto" align="center" label="头像" /><el-table-column prop="username" label="姓名" /><el-table-column prop="mobile" label="手机号" sortable /><el-table-column prop="workNumber" label="工号" sortable /><el-table-column prop="formOfEmployment" label="聘用形式" /><el-table-column prop="departmentName" label="部门" /><el-table-column prop="timeOfEntry" label="入职时间" sortable />...
</el-table>

10.员工管理-头像和聘用形式的处理

  • 头像的设置-代码位置(src/views/employee/index.vue)
 <el-table-column prop="staffPhoto" align="center" label="头像"><template v-slot="{ row }"><el-avatar v-if="row.staffPhoto" :src="row.staffPhoto" :size="30" /><span v-else class="username">{{ row.username?.charAt(0) }}</span></template>
</el-table-column>
  • 聘用形式的处理-代码位置(src/views/employee/index.vue)
<el-table-column prop="formOfEmployment" label="聘用形式"><template v-slot="{ row }"><span v-if="row.formOfEmployment === 1">正式</span><span v-else-if="row.formOfEmployment === 2">非正式</span><span v-else></span></template>
</el-table-column>

11.员工管理-员工分页处理

在这里插入图片描述

  • 定义分页参数(src/views/employee/index.vue)
data(){return{queryParams:{departmentId:null,page:1,//当前页码paesize:10 },total:0,//记录员工的总数}
}
  • 绑定分页参数
<el-paginationlayout="total,prev, pager, next":total="total":current-page="queryParams.page":page-size="queryParams.pagesize"@current-change="changePage"/>
  • 切换页码事件(src/views/employee/index.vue)
changePage(newPage){this.queryParams.page = newPage //赋值新页码this.getEmployeeList()//查询数据
}
  • 切换部门时,查询第一页数据(src/views/employee/index.vue)
selectNode(node){this.queryParams.page = 1;//设置第一页
}

12.员工管理-员工模糊搜索

  • 设置模糊搜索的参数字段(src/views/employee/index.vue)
 queryParams: {departmentId: null,page:1,//当前页码pageSize:10,keyword:''//模糊搜索字段},
  • 双向绑定input输入框,监听值改变事件
<el-input v-model="queryParams.keyword" prefix-icon="el-icon-search" size="small" placeholder="输入员工姓名全员搜索" @input="changeValue" /> 
  • input事件只要内容发生变化就会触发,change事件是离开焦点触发
  • 值改变查询数据-防抖
 changeValue() {// 单位时间内只执行最后一次// this的实例上赋值了一个timer的属性clearTimeout(this.timer) // 清理上一次的定时器this.timer = setTimeout(() => {this.queryParams.page = 1this.getEmployeeList()}, 300)
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3227350.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

算法的复杂度

文章目录 一、算法的效率1、复杂度的概念2、复杂度的重要性 二、时间复杂度三、空间复杂度四、大O的渐进表示发五、计算复杂度案例1、计算Func1函数的复杂度2、计算Fun2的时间复杂度3、计算Func3的时间复杂度4、计算Func4的时间复杂度5、计算strchr的时间复杂度6、计算Func5的时…

SuperCLUE最新测评发布,360智脑大模型稳居大模型第一梯队

7月9日&#xff0c;国内权威大模型评测机构SuperCLUE发布《中文大模型基准测评2024上半年报告》&#xff0c;360智脑大模型&#xff08;360gpt2-pro&#xff09;在SuperCLUE基准6月测评中&#xff0c;取得总分72分&#xff0c;超过GPT-3.5-Turbo-0125&#xff0c;位列国内大模型…

[GICv3] 3. 物理中断处理(Physical Interrupt Handling)

中断生命周期 ​​ 外设通过中断信号线生成中断&#xff0c;或者软件生成中断&#xff08;SGI&#xff09;。Distributor 和 ReDistributor 配合按照中断分组和中断优先级仲裁后将最高优先级的中断分发到 CPU interface。cpu interface 向中断发送到 PEPE 读取 IAR 寄存器&am…

Global Mapper:地理信息的温柔探索

引言 在这纷繁复杂的世界里&#xff0c;地理信息系统&#xff08;GIS&#xff09;如同一把利器&#xff0c;帮助我们剖析、理解和改造这个世界。而在众多GIS软件中&#xff0c;Global Mapper无疑是其中的佼佼者。作为一款功能全面且易于使用的GIS应用程序&#xff0c;Global M…

【服务器】在Linux查看运行的Python程序,并找到特定的Python程序

在Linux查看运行的Python程序并找到特定的Python程序 写在最前面1. 使用ps命令查看所有Python进程查看详细信息 2. 使用pgrep命令查找Python进程ID 3. 使用top或htop命令使用top命令使用htop命令 4. 使用lsof命令查找Python进程打开的文件 5. 使用nvidia-smi命令查看GPU使用情况…

InstructPix2Pix Learning to Follow Image Editing Instructions

InstructPix2Pix: Learning to Follow Image Editing Instructions TL; DR&#xff1a;核心是使用 GPT3 SD P2P 来机造指令编辑训练数据。 数据 本文要做的事情是教会模型根据指令来进行图像编辑。样例如下图所示&#xff0c;给定一张向日葵的图片和指令 “将向日葵换为玫…

zynq使用简单I/O对Flash进行读写测试

硬件环境&#xff1a;ALINX 7020 ZYNQ的QSPI Flash 控制器有以下三种模式&#xff1a;I/O 模式、线性地址模式&#xff0c;以及传统 SPI 模式。 I/O模式 操作特点&#xff1a;在I/O模式下&#xff0c;软件模拟去实现 Flash 器件的通信协议。软件需要将 Flash 命令和数据写到控…

【深度学习入门篇 ②】Pytorch完成线性回归!

&#x1f34a;嗨&#xff0c;大家好&#xff0c;我是小森( &#xfe61;ˆoˆ&#xfe61; )&#xff01; 易编橙终身成长社群创始团队嘉宾&#xff0c;橙似锦计划领衔成员、阿里云专家博主、腾讯云内容共创官、CSDN人工智能领域优质创作者 。 易编橙&#xff1a;一个帮助编程小…

二四、3d人脸构建

一、下载github项目3dmm_cnn-master https://github.com/anhttran/3dmm_cnn.git 一个使用深度神经网络从单个图像进行 3D 人脸建模的项目,端到端代码,可直接根据图像强度进行 3D 形状和纹理估计;使用回归的 3D 面部模型,从检测到的面部特征点估计头部姿势和表情。…

STM32中断学习记录

文章目录 NVICNVIC是什么NVIC寄存器NVIC 结构体NVIC 相关固件库函数 如何定义优先级中断编程外部中断 EXTIEXIT 外部中断/事件控制器EXIT的使用EXTI内部寄存器分析GPIO触发中断例程为什么中断后要清除中断标志位 SysTick的使用SysTick分析 NVIC NVIC是什么 待补充.........NVI…

Docker安装HomeAssistant

检查Docker服务是否正常运行&#xff0c;确保Docker正常运行。 systemctl status docker#输出---------------------- docker.service - Docker Application Container EngineLoaded: loaded (/usr/lib/systemd/system/docker.service; enabled; vendor preset: disabled)Activ…

旗晟智能巡检机器人:开启工业运维的智能化新篇章

在当今快速发展的工业领域&#xff0c;安全、效率和成本控制是企业运营的核心。旗晟科技以创新为驱动&#xff0c;推出了一站式的工业级智能巡检机器人数字化全景运维解决方案&#xff0c;为石油、天然气、化工、电力等高危行业提供了一个全新的运维模式。 一、面对挑战&#x…

人工智能算法工程师(中级)课程3-sklearn机器学习之数据处理与代码详解

大家好&#xff0c;我是微学AI,今天给大家分享一下人工智能算法工程师(中级)课程3-sklearn机器学习之数据处理与代码详解。 Sklearn&#xff08;Scikit-learn&#xff09;是一个基于Python的开源机器学习库&#xff0c;它提供了简单有效的数据挖掘和数据分析工具。Sklearn包含了…

动手学深度学习(Pytorch版)代码实践 -循环神经网络-57长短期记忆网络(LSTM)

57长短期记忆网络&#xff08;LSTM&#xff09; 1.LSTM原理 LSTM是专为解决标准RNN的长时依赖问题而设计的。标准RNN在训练过程中&#xff0c;随着时间步的增加&#xff0c;梯度可能会消失或爆炸&#xff0c;导致模型难以学习和记忆长时间间隔的信息。LSTM通过引入一组称为门…

碾压SOTA!最新视觉SLAM:渲染速度提升176倍,内存占用减少150%

视觉SLAM&#xff0c;一种结合了CV与机器人技术的先进方法。与激光SLAM相比&#xff0c;它成本低廉且信息量大&#xff0c;易于安装&#xff0c;拥有更优秀的场景识别能力&#xff0c;因此在自动驾驶等许多场景上都非常适用&#xff0c;是学术界与工业界共同关注的热门研究方向…

如何将heic格式转换jpg?四种将heic转换成jpg的方法!

如何将heic格式转换jpg&#xff1f;在现今的数字图像处理领域&#xff0c;Heic格式作为一种被吹捧的创新型图像格式&#xff0c;以其先进的压缩技术&#xff0c;迅速减小了图片文件的大小&#xff0c;然而&#xff0c;尽管其有许多优点&#xff0c;实际使用中Heic格式却带来了一…

RSA加密算法因N强度不足破解实例

已知如下RSA密文和公钥信息&#xff0c;要求解密得到明文。 ----------------------- ciphertext&#xff08;HEX&#xff09; 94808F954A8AF9B9 N&#xff08;HEX&#xff09; C6EAD137492B4631 e&#xff08;HEX&#xff09; 10001 ------------------------ 分析过…

【Linux】命令执行的判断依据:;,,||

在某些情况下&#xff0c;很多命令我想要一次输入去执行&#xff0c;而不想要分次执行时&#xff0c;该如何是好&#xff1f; 基本上有两个选择&#xff0c; 一个是通过shell脚本脚本去执行&#xff0c;一种则是通过下面的介绍来一次入多个命令。 1.cmd&#xff1a;cmd&#…

【Android】基于 LocationManager 原生实现定位打卡

目录 前言一、实现效果二、定位原理三、具体实现1. 获取权限2. 页面绘制3. 获取经纬度4. 方法调用5. 坐标转换6. 距离计算7. 完整代码 前言 最近公司有个新需求&#xff0c;想要用定位进行考勤打卡&#xff0c;在距离打卡地一定范围内才可以进行打卡。本文将借鉴 RxTool 的 Rx…

buuctf面具下的flag

细节: 这道题可能因为是vmdk的原因 导致在window上 7z无法得到全部的信息 所以最后解压要在linux系统上 解密网站 Brainfuck/Ook! Obfuscation/Encoding [splitbrain.org] 这道题010打开,可以发现里面隐藏了很多 binwalk解压 两个文件 vmdk可以直接 用7z解压 7z x flag.…