记录el-select+el-tree复选框,支持模糊查询,懒加载,树父子节点不关联,不全选

需求:一个机构下拉菜单,一个人员下拉菜单,默认带入当前登录用户的机构和人员。机构下拉菜单为两个接口,模糊查询为一个接口不包含懒加载,默认非模糊查询情况下为一个接口,点击节点懒加载。机构下拉菜单数据变动更新人员下拉菜单数据。日期默认为当天

<template><div class="app-container"><div id="app" class="mb82 grid-content pd20"><div><el-row :gutter="20"><el-col id="tittle">检查信息</el-col></el-row><el-divider ></el-divider></div><div class="center"><el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm"><el-form-item label="检查时间:" prop="checkTime"><el-date-pickerclass="width100"v-model="ruleForm.checkTime"type="date"value-format="yyyy-MM-dd HH:mm:ss"placeholder="选择日期"></el-date-picker></el-form-item><el-form-item label="检查机构:" prop="selectOrg"><el-selectclass="el-input-search width100"v-model="ruleForm.selectOrg"ref="refSelectOrg":multiple="true"@remove-tag="removetagOrg"@clear="clearallOrg"clearable@change ="$forceUpdate();"><el-optionvalue=""style="height:auto;background-color: #fff;"><el-input:validate-event="false"v-model="filterTextOrg"ref="refSelectOrgSearch"placeholder="请输入"@click.stop.nativeclearable@clear="clearallOrgSearch"style="margin-bottom:8px;"></el-input><el-tree:show-checkbox="true"style="padding:20px 10px;":data="orgList":props="defaultPropsOrg"node-key="orgId"check-strictlyhighlight-current:expand-on-click-node="true"ref="refTreeOrg":default-expanded-keys="expandedKeysOrgData":default-checked-keys="checkedKeysOrgData"@check-change="handleNodeCheckOrg"@node-click="handleNodeClick"></el-tree></el-option></el-select></el-form-item><el-form-item label="检查人员:" prop="selectUser"><el-selectclass="el-input-search width100"v-model="ruleForm.selectUser"ref="refSelectOrg":multiple="true"@remove-tag="removetagUser"@clear="clearallUser"clearable@change ="$forceUpdate();"><el-optionvalue=""style="height:auto;background-color: #fff;"><el-input:validate-event="false"v-model="filterTextUser"ref="refSelectUserSearch"placeholder="请输入"@click.stop.nativeclearable@clear="clearallUserSearch"style="margin-bottom:8px;"></el-input><el-tree:show-checkbox="true"style="padding:20px 10px;":data="userList":props="defaultPropsUser"node-key="userId"check-strictlyhighlight-current:expand-on-click-node="true"ref="refTreeUser":default-expanded-keys="expandedKeysUserData":default-checked-keys="checkedKeysUserData"@check-change="handleNodeCheckUser"></el-tree></el-option></el-select></el-form-item><el-form-item label="检查结果:" prop="checkResult"><el-input type="textarea" v-model="ruleForm.checkResult"></el-input></el-form-item></el-form></div></div><div class="footerBtn bg"><el-divider></el-divider><el-row class="pd20"><el-col :span="23" style="text-align: right;"><el-button size="small" @click="goback">返回</el-button><el-button type="primary" size="small" @click="submitBtn('ruleForm')">提交</el-button></el-col></el-row></div></div>
</template><script>
import axios from "axios";
import {warnView,getInfo,childNode,childNodeFuzzyQuery,getUserListByOrg,saveCheck} from "../../../../api/warning"
export default {data() {return {// 检察机构startfilterTextOrg:'',orgList:[],defaultPropsOrg: {children: 'childNodeList',label: 'orgName',value:'orgId',isLeaf: 'leaf'},expandedKeysOrgData:['792394093041156096'],checkedKeysOrgData:[],nodeCheckedOrgData:[],// 检察机构end// 检察人员startfilterTextUser:'',userList:[],defaultPropsUser: {children: 'userList',label: 'realName',value:'userId',isLeaf: 'leaf'},expandedKeysUserData:[],checkedKeysUserData:[],nodeCheckedUserData:[],// 检察人员endruleForm: {checkTime: '',selectOrg: [],selectUser: [],checkResult: '',},rules: {checkTime: [{ required: true, message: '检查时间不能为空', trigger: 'change' },],selectOrg: [{ type: 'array', required: true, message: '检查机构不能为空', trigger: 'change' },],selectUser: [{ type: 'array', required: true, message: '检查人员不能为空', trigger: 'change' },],checkResult: [{ required: true, message: '检查结果不能为空', trigger: 'blur' },],},orgId:'',orgName:'',}},watch: {// 检察机构start// 监听输入值filterTextOrg(val) {if(val){this.childNodeFuzzyQueryChange(val)}else{this.childNodeChangeAll(this.orgId)}},'ruleForm.selectOrg': {handler: function (newVal, oldVal) {let that = thisif(newVal){// this.$refs.refTreeOrg.filter(newVal);}else{console.log('newVal1111111',newVal)}},deep: true},// 检察机构end// 检察人员startfilterTextUser(val) {this.getUserListByOrgChange(val)},// 检察人员end},created() {getInfo("").then((res) => {this.userId = res.data.userId;this.realName = res.data.realName;this.orgId = res.data.orgId;this.orgName = res.data.orgName;this.nodeCheckedOrgData = [{orgId:this.orgId,orgName:this.orgName,}]this.ruleForm.selectOrg.push(this.orgName)this.checkedKeysOrgData.push(this.orgId)this.childNodeChangeAll('792394093041156096')this.nodeCheckedUserData = [{userId:this.userId,realName:this.realName,}]this.ruleForm.selectUser.push(this.realName)this.checkedKeysUserData.push(this.userId)this.getUserListByOrgChange();})},mounted() {this.ruleForm.superviseId = this.$route.query.superviseId; // 监管idDate().getTime(); // 检查编号this.ruleForm.checkTime = this.dateTypeFormat('YYYY-mm-dd HH:MM:SS', new Date())},methods: {// 去重unique(arr){return Array.from(new Set(arr))},// 返回上一页goback() {this.$router.go(-1);},// 格式化日期dateTypeFormat(fmt, date) {let retconst opt = {'Y+': date.getFullYear().toString(), // 年'm+': (date.getMonth() + 1).toString(), // 月'd+': date.getDate().toString(), // 日'H+': date.getHours().toString(), // 时'M+': date.getMinutes().toString(), // 分'S+': date.getSeconds().toString() // 秒// 有其他格式化字符需求可以继续添加,必须转化成字符串}for (const k in opt) {ret = new RegExp('(' + k + ')').exec(fmt)if (ret) {fmt = fmt.replace(ret[1], (ret[1].length === 1) ? (opt[k]) : (opt[k].padStart(ret[1].length, '0')))}}return fmt},
// 检察机构start// 获取模糊查询机构树childNodeFuzzyQueryChange(val){let data = {orgId:'',value:val}childNodeFuzzyQuery(data).then((res) => {this.orgList = res.data || [];})},// 获取机构树非模糊查询childNodeChangeAll(id){let orgId = id || ''childNode(orgId).then((res) => {res.data.node.childNodeList = res.data.childOrgListthis.orgList = []this.orgList.push(res.data.node);})},// 删除机构单个下拉菜单标签removetagOrg(val){this.nodeCheckedOrgData.forEach((item, index, arr) => {if(item.orgName === val) {arr.splice(index, 1)this.checkedKeysOrgData = this.checkedKeysOrgData.filter(i => i !== item.orgId)}})this.checkedKeysOrgData = this.unique(this.checkedKeysOrgData)this.$nextTick(() => {this.$refs.refTreeOrg.setCheckedKeys(this.checkedKeysOrgData,true)})// 数据变动更改人员树this.nodeCheckedUserData=[];this.ruleForm.selectUser=[];this.checkedKeysUserData=[];this.getUserListByOrgChange('')},// 清空机构下拉菜单clearallOrg(){},// 清空机构模糊查询clearallOrgSearch(){},// 点击机构树复选框handleNodeCheckOrg(data,checked){if(checked === true) {this.ruleForm.selectOrg.push(data.orgName)this.checkedKeysOrgData.push(data.orgId)this.nodeCheckedOrgData.push(data)if(this.ruleForm.selectOrg)this.ruleForm.selectOrg = this.unique(this.ruleForm.selectOrg)this.checkedKeysOrgData = this.unique(this.checkedKeysOrgData)const map = new Map();this.nodeCheckedOrgData.filter(i => !map.has(i.orgId) && map.set(i.orgId, i));this.$refs.refTreeOrg.setChecked(data.orgId, true)}else{this.nodeCheckedOrgData.forEach((item, index, arr) => {if(item.orgId === data.orgId) {arr.splice(index, 1)this.checkedKeysOrgData = this.checkedKeysOrgData.filter(i => i !== item.orgId)}})if(this.ruleForm.selectOrg.includes(data.orgName)) {this.ruleForm.selectOrg.forEach((item, index, arr) => {if(item === data.orgName) {arr.splice(index, 1)}})this.$refs.refTreeOrg.setChecked(data.orgId, false)}}// 数据变动更改人员树this.nodeCheckedUserData=[];this.ruleForm.selectUser=[];this.checkedKeysUserData=[];this.getUserListByOrgChange('')},// 点击机构树节点handleNodeClick(data,node){console.log(data)console.log(node)let that = thislet orgId = '';if (node.level >= 1) {orgId = node.data.orgId;}childNode(orgId).then((res) =>{if(res.code == 20000){let parentData = [];let data;if (node.level === 0) {parentData[0] = res.data.nodedata = parentData;}if (node.level >= 1) {data = res.data.childOrgList;}//TODO 追加数据 append datathis.$refs.refTreeOrg.updateKeyChildren(orgId,res.data.childOrgList);setTimeout(()=>{if(res.data.childOrgList){ node.expanded = true}},300)} else {this.$message({message: res.message,type: "error"});}})},
// 检查机构end
// 检察人员start// 获取模糊查询人员树getUserListByOrgChange(val){this.checkedKeysOrgData = this.unique(this.checkedKeysOrgData)let data = {orgIds:this.checkedKeysOrgData,searchValue:val || ''}getUserListByOrg(data).then((res) => {this.userList = res.data || [];})},// 删除人员单个下拉菜单标签removetagUser(val){this.nodeCheckedUserData.forEach((item, index, arr) => {if(item.realName === val) {arr.splice(index, 1)this.checkedKeysUserData = this.checkedKeysUserData.filter(i => i !== item.userId)}})this.checkedKeysUserData = this.unique(this.checkedKeysUserData)this.$nextTick(() => {this.$refs.refTreeUser.setCheckedKeys(this.checkedKeysUserData,true)})},// 清空人员下拉菜单clearallUser(){},// 清空人员模糊查询clearallUserSearch(){},// 点击人员树复选框handleNodeCheckUser(data,checked){if(checked === true) {this.ruleForm.selectUser.push(data.realName)this.checkedKeysUserData.push(data.userId)this.nodeCheckedUserData.push(data)if(this.ruleForm.selectUser)this.ruleForm.selectUser = this.unique(this.ruleForm.selectUser)this.checkedKeysUserData = this.unique(this.checkedKeysUserData)const map = new Map();this.nodeCheckedUserData.filter(i => !map.has(i.userId) && map.set(i.userId, i));this.$refs.refTreeUser.setChecked(data.userId, true)}else{this.nodeCheckedUserData.forEach((item, index, arr) => {if(item.userId === data.userId) {arr.splice(index, 1)this.checkedKeysUserData = this.checkedKeysUserData.filter(i => i !== item.userId)}})if(this.ruleForm.selectUser.includes(data.realName)) {this.ruleForm.selectUser.forEach((item, index, arr) => {if(item === data.realName) {arr.splice(index, 1)}})this.$refs.refTreeUser.setChecked(data.userId, false)}}},// 检查人员end// 表单提交弹窗submitBtn(formName){this.$refs[formName].validate((valid) => {if (valid) {this.$confirm('确定提交吗?', '提示', {confirmButtonText: '确定',cancelButtonText: '取消',type: 'warning'}).then(() => {this.submitChange();}).catch(() => {this.$message({type: 'info',message: '已取消'});});} else {return false;}});},// 提交表单submitChange(){const map = new Map();this.nodeCheckedOrgData = this.nodeCheckedOrgData.filter(i => !map.has(i.orgId) && map.set(i.orgId, i));this.nodeCheckedUserData = this.nodeCheckedUserData.filter(i => !map.has(i.userId) && map.set(i.userId, i));this.ruleForm.orgList = this.nodeCheckedOrgData;this.ruleForm.userList = this.nodeCheckedUserData;let data = {superviseId:this.ruleForm.superviseId,orgList:this.ruleForm.orgList,userList:this.ruleForm.userList,checkResult:this.ruleForm.checkResult,checkTime:this.ruleForm.checkTime,}console.log('data',data)saveCheck(data).then((res) => {if(res.code == '20000'){this.$message({message: '提交成功',type: 'success'});this.$router.go(-1);}else{this.$message({message: res.message,type: 'error'});}})},}
}
</script><style scoped lang="less">
.app-container {margin: 10px;
}
#app {/* padding: 15px; */background-color: #fff;font-size: 14px;
}.title{text-align: center;color: #0066FF;font-weight:800;font-size: 16px;}.chart-container{position: relative;width: 100%;height: calc(100vh - 84px);}.description{font-size: 12px;padding-left: 20px;color: #555;}.mt10{margin-top: 10px;}.mg15-0{margin: 15px 0;}.mt30{margin-top: 30px;}.mt26{margin-top: 26px;}.state-box{width: 10px;height: 10px;margin-right: 5px;margin-bottom: 1px;display: inline-block;}.state-box-max {width: 19px;height: 16px;text-align: center;line-height: 16px;color: #fff;margin-right: 10px;margin-top: 1px;display: inline-block;}.violet{background: #9933FF;}.yellow{background: #e6a23c;}.blue{background: #0066FF;}.footerBtn{position: fixed;bottom: 0;right: 0;z-index: 9;width: calc(100%);-webkit-transition: width 0.28s;transition: width 0.28s;}.el-divider--horizontal{margin: 0px 15px;}.bg{background: #fff;}.el-col{margin:0 24px;}.pdt10{padding-top: 10px;}.mb15{margin-bottom: 15px;}.mb82{margin-bottom: 82px;}.mb60{margin-bottom: 60px;}.mb10{margin-bottom: 10px;margin-top: 10px;}.diaglogClas{margin-bottom: 15px;}.grid-content {/*  padding-top: 15px; */border-radius: 4px;min-height: 36px;background: #fff;}.bg-purple {/* background: #dddfe6; */width: 100%;height: 55px;line-height: 55px;font-size: 12px;/* font-weight:800; */text-align: center;border: 1px solid #d3dce6;}.expClas{float: right;position: initial;margin-top: 30px;}.footCenter{text-align: center;}
/deep/.el-autocomplete-suggestion{display: inline-table;
}
.width100{width: 100%;}
.center{width: 700px;margin: 0 auto;padding-top: 20px;padding-bottom: 20px;
}
.footerBtn{position: fixed;bottom: 0;right: 0;z-index: 9;width: calc(100%);-webkit-transition: width 0.28s;transition: width 0.28s;
}
.bg{background: #fff;}
.pd20{padding: 15px;padding-right: 0;}
</style>

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

NACHI机器人虚拟示教器报I2101异常

前言 机器人示教器报&#xff1a;I2101 异常停止按钮或外部停止信号被输入 无法再示教模式下进行程序的运行&#xff01; 解决方法 结果 最后测试可以正常的运行程序

细说DMD芯片信号-DLP3

1&#xff0c; Block diagram 2. 信号介绍 2.1, LS interface&#xff1a; LD_Data_P/N(i), LD_CLK_P/N(i), LS_RDATA_A_BIST(O) 2.2, 视频信号: HSSI(High speed serial interface) High speed Differential Data pair lan A0~7 P/N, High speed Differential Clock A High…

如何使用人工智能优化 DevOps?

DevOps 和人工智能密不可分&#xff0c;影响着各种业务。DevOps 可以加快产品开发速度并简化现有部署的维护&#xff0c;而 AI 则可以改变整个系统的功能。DevOps团队可以依靠人工智能和机器学习来进行数据集成、测试、评估和发布系统。更重要的是&#xff0c;人工智能和机器学…

uniapp 微信小程序跳转至其他小程序

一、背景&#xff1a; 需要在目前的小程序中跳转到另一个小程序&#xff0c;跳转的目标小程序需要已经发布上线了 二、具体实现 使用uni.navigateToMiniProgram打开另一个小程序 官网指引&#x1f449;&#xff1a;uni.navigateToMiniProgram(OBJECT) | uni-app官网 <t…

IDEA中明明代码没有报错,运行也不报错,但是代码却爆红了,重启idea,重启电脑,重新加载Maven都没有用

报错示图&#xff1a; 报错类是存在的 我的解决办法是修改类名&#xff0c;修改类名时会有提示&#xff0c;如下图&#xff1a; 然后点击报错的地方可以看到是哪些位置引用了 改回正确的类名 正常显示

酚醛胶面建筑模板 — 广西厂家直销,质保可靠

在现代建筑行业中&#xff0c;选择高质量的建筑板材对于确保施工质量和工程安全至关重要。广西厂家直销的酚醛胶面建筑板&#xff0c;以其卓越的质量和可靠的质保&#xff0c;成为了建筑行业的优选材料。 产品特性 卓越的耐候性&#xff1a;我们的酚醛胶面建筑板采用高品质酚醛…

Keras实现seq2seq

概述 Seq2Seq是一种深度学习模型&#xff0c;主要用于处理序列到序列的转换问题&#xff0c;如机器翻译、对话生成等。该模型主要由两个循环神经网络&#xff08;RNN&#xff09;组成&#xff0c;一个是编码器&#xff08;Encoder&#xff09;&#xff0c;另一个是解码器…

MC-4/11/10/400​什么是电机驱动器。​

MC-4/11/10/400​什么是电机驱动器。​ 首先&#xff0c;我们先来了解以下两个主题&#xff0c;这会帮助我们了解什么是电机驱动器。 电机驱动器IC的作用 电机驱动器IC与电机设备之间的关系 电机驱动器的作用 用来使电机旋转&#xff08;驱动电机&#xff09;的集成电路&…

R语言【paleobioDB】——pbdb_collections():通过参数选择,返回多个采集号的基本信息

Package paleobioDB version 0.7.0 paleobioDB 包在2020年已经停止更新&#xff0c;该包依赖PBDB v1 API。 可以选择在Index of /src/contrib/Archive/paleobioDB (r-project.org)下载安装包后&#xff0c;执行本地安装。 Usage pbdb_collections (...) Arguments 参数【...…

云防护概念及云防护作用

云防护是什么 云防护是一种网络安全技术&#xff0c;旨在保护云计算环境中的数据和系统免受恶意攻击和未授权访问。 云防护适用场景 一切http.https.tcp协议&#xff0c;如游戏、电商、金融、物联网等APP PC 网站。 云防护的主要作用 云防护的主要作用是通过搭规模庞大的云防…

STM32存储左右互搏 SPI总线读写FRAM MB85RS2M

STM32存储左右互搏 SPI总线读写FRAM MB85RS2M 在中低容量存储领域&#xff0c;除了FLASH的使用&#xff0c;&#xff0c;还有铁电存储器FRAM的使用&#xff0c;相对于FLASH&#xff0c;FRAM写操作时不需要预擦除&#xff0c;所以执行写操作时可以达到更高的速度&#xff0c;其…

数字后端设计实现之自动化useful skew技术(Concurrent Clock Data)

在数字IC后端设计实现过程中&#xff0c;我们一直强调做时钟树综合要把clock skew做到最小。原因是clock skew的存在对整体设计的timing是不利的。 但是具体到某些timing path&#xff0c;可能它的local clock skew对timing是有帮助的&#xff0c;比如如下图所示。 第一级FF到第…

搭建Eureka服务注册中心

一、前言 我们在别的章节中已经详细讲解过eureka注册中心的作用&#xff0c;本节会简单讲解eureka作用&#xff0c;侧重注册中心的搭建。 Eureka作为服务注册中心可以进行服务注册和服务发现&#xff0c;注册在上面的服务可以到Eureka上进行服务实例的拉取&#xff0c;主要作用…

LeetCode[105] 从前序与中序遍历序列构造二叉树

给定两个整数数组 preorder 和 inorder &#xff0c;其中 preorder 是二叉树的先序遍历&#xff0c; inorder 是同一棵树的中序遍历&#xff0c;请构造二叉树并返回其根节点。 示例 1: 输入: preorder [3,9,20,15,7], inorder [9,3,15,20,7] 输出: [3,9,20,null,null,15,7] …

为什么推荐大家使用动态住宅ip?怎么选择?

代理ip的类型有很多&#xff0c;本文来介绍什么是动态住宅ip&#xff0c;为什么很多博主都推荐使用动态住宅ip&#xff0c;他到底有什么好处呢&#xff0c;接下来我们来学习一下。 一、什么是动态住宅ip 网络上的代理供应商很多&#xff0c;通常我们接触的比较多的几种类型有…

Ubuntu下Lighttpd服务器安装,并支持PHP

1、说明 Lighttpd 是一个德国人领导的开源Web服务器软件&#xff0c;其根本的目的是提供一个专门针对高性能网站&#xff0c;安全、快速、兼容性好并且灵活的web server环境。具有非常低的内存开销、cpu占用率低、效能好以及丰富的模块等特点。 Lighttpd是众多OpenSource轻量级…

模型评估:Holdout、交叉检验、自助法

机器学习中&#xff0c;我们通常把样本分为训练集和测试集&#xff0c;训练集用于训练模型&#xff0c;测试集用于评估模型。在样本划分和模型验证的过程中&#xff0c;存在着不同的抽样方法和验证方法。 1. 在模型评估过程中&#xff0c;有哪些主要的验证方法&#xff0c;它们…

[计算机提升] 创建FTP共享

4.7 创建FTP共享 4.7.1 FTP介绍 在Windows系统中&#xff0c;FTP共享是一种用于在网络上进行文件传输的标准协议。它可以让用户通过FTP客户端程序访问并下载或上传文件&#xff0c;实现文件共享。 FTP共享的用途非常广泛&#xff0c;例如可以让多个用户共享文件、进行文件备份…

Elasticsearch 索引文档时create、index、update的区别【学习记录】

本文基于elasticsearch7.3.0版本。 一、思维导图 elasticsearch中create、index、update都可以实现插入功能&#xff0c;但是实现原理并不相同。 二、验证index和create 由上面思维导图可以清晰的看出create、index的大致区别&#xff0c;下面我们来验证下思维导图中的场景&…

系列二、Spring Security中的核心类

一、Spring Security中的核心类 1.1、自动配置类 UserDetailsServiceAutoConfiguration 1.2、密码加密器 1.2.1、概述 Spring Security 提供了多种密码加密方案&#xff0c;官方推荐使用 BCryptPasswordEncoder&#xff0c;BCryptPasswordEncoder 使用 BCrypt 强哈希函数&a…