<template> <div id="content"> <div v-if="formAll&&formAllBody&&formAllBody.length" style="text-align:left;padding:10px"> <el-select v-model="querySite" @change="selectChange"> <el-option v-for="item in querySiteList" :key="item" :label="item" :value="item" > <span style="float: left">{{ item }}</span> </el-option> </el-select> <el-button type="primary" @click="echoClick"> 回显 </el-button> <el-button type="primary" @click="temStorage"> 暂存 </el-button> <el-button type="primary" @click="temStorageEcho"> 暂存回显 </el-button> <el-button type="primary" @click="sunmitAll"> 提交 </el-button> </div> <div id="navMenuContent"> <el-menu :default-active="activeIndex" class="el-menu-demo" mode="horizontal" @select="handleSelect" type="border-card"> <el-menu-item v-for="(item,index) in siteNameList" :index="`${index}`" :key="index">{{item}}</el-menu-item> </el-menu> </div> <div class="switchContent"> <div v-if="formAll&&formAllBody&&formAllBody.length"> <div v-for="(formItem,formItemIndex) in formAll" :key="formItemIndex"> <el-form v-show="formItem[`form${formItemIndex+1}Show`]" :model="formItem[`form${formItemIndex+1}`]" :rules="rules" ref="form" class="demo-ruleForm" label-position="right" label-width="130px" size="mini" > <!-- {{`form${index+1}`}} --> <el-row v-for="(i,index) in formAllBody[formItemIndex+1] " :key="index" class="rowClass"> <el-col :span="6" v-if="i.name" class="subTitle">{{i.name}}</el-col> <el-col :span="6" v-for="(item,index) in i.data " :key="index" style="position:relative"> <el-form-item v-if="parseInt(item.fieldType) === 1" :label="item.fieldName" :prop="item.fieldIdentifier" class="el-form-item-input"> <el-input v-model="formItem[`form${formItemIndex+1}`][item.fieldIdentifier]" :placeholder="item.validatorMark"><i slot="suffix">{{item.unit}}</i></el-input> </el-form-item> <el-form-item v-if="parseInt(item.fieldType) === 2" :label="item.fieldName" :prop="item.fieldIdentifier" class="el-form-item-input"> <el-select v-model="formItem[`form${formItemIndex+1}`][item.fieldIdentifier]" :placeholder="item.validatorMark"> <el-option v-for="item in creatListTest(item.selectOption)" :key="item.code" :label="item.value" :value="item.value" > <span style="float: left">{{ item.value }}</span> </el-option> </el-select> </el-form-item> <el-form-item v-if="parseInt(item.fieldType) === 3" :label="item.fieldName" :prop="item.fieldIdentifier" class="el-form-item-input form-switch"> <el-switch v-model="formItem[`form${formItemIndex+1}`][item.fieldIdentifier]" active-color="#13ce66" inactive-color="#ff4949"></el-switch> </el-form-item> <el-form-item v-if="parseInt(item.fieldType) === 5" :label="item.fieldName" :prop="item.fieldIdentifier" class="el-form-item-input"> <el-input v-model="formItem[`form${formItemIndex+1}`][item.fieldIdentifier]" :placeholder="item.validatorMark"><i slot="suffix">{{item.unit}}</i></el-input> </el-form-item> <div v-if="parseInt(item.fieldType) === 4" class="input-switch-div"> <el-form-item :prop="item.fieldIdentifier" class="el-form-item-input input-switch" style="flex:1"> <!-- <el-input v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}input${0}`]" :placeholder="item.validatorMark"></el-input> --> <el-input v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}input${0}`]" :placeholder="item.validatorMark"></el-input> </el-form-item> <el-form-item class="el-form-item-input input-switch" style="flex:1;"> <el-switch v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}switch${0}`]" active-color="#13ce66" inactive-color="#ff4949"></el-switch> </el-form-item> <el-form-item :prop="item.fieldIdentifier" class="el-form-item-input input-switch" style="flex:1"> <el-input v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}input${1}`]" :placeholder="item.validatorMark"></el-input> </el-form-item> <el-form-item class="el-form-item-input input-switch" style="flex:1"> <el-switch v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}switch${1}`]" active-color="#13ce66" inactive-color="#ff4949"></el-switch> </el-form-item> <el-form-item :prop="item.fieldIdentifier" class="el-form-item-input input-switch" style="flex:1"> <el-input v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}input${2}`]" :placeholder="item.validatorMark"></el-input> </el-form-item> <el-form-item class="el-form-item-input input-switch" style="flex:1"> <el-switch v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}switch${2}`]" active-color="#13ce66" inactive-color="#ff4949"></el-switch> </el-form-item> <el-form-item :prop="item.fieldIdentifier" class="el-form-item-input input-switch" style="flex:1"> <el-input v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}input${3}`]" :placeholder="item.validatorMark"></el-input> </el-form-item> <el-form-item class="el-form-item-input input-switch" style="flex:1"> <el-switch v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}switch${3}`]" active-color="#13ce66" inactive-color="#ff4949"></el-switch> </el-form-item> <el-form-item :prop="item.fieldIdentifier" class="el-form-item-input input-switch" style="flex:1"> <el-input v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}input${4}`]" :placeholder="item.validatorMark"></el-input> </el-form-item> <el-form-item class="el-form-item-input input-switch" style="flex:1;"> <el-switch v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}switch${4}`]" active-color="#13ce66" inactive-color="#ff4949"></el-switch> </el-form-item> <el-form-item :prop="item.fieldIdentifier" class="el-form-item-input input-switch" style="flex:1"> <el-input v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}input${5}`]" :placeholder="item.validatorMark"></el-input> </el-form-item> <el-form-item class="el-form-item-input input-switch" style="flex:1"> <el-switch v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}switch${5}`]" active-color="#13ce66" inactive-color="#ff4949"></el-switch> </el-form-item> <el-form-item :prop="item.fieldIdentifier" class="el-form-item-input input-switch" style="flex:1"> <el-input v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}input${6}`]" :placeholder="item.validatorMark"></el-input> </el-form-item> <el-form-item class="el-form-item-input input-switch" style="flex:1"> <el-switch v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}switch${6}`]" active-color="#13ce66" inactive-color="#ff4949"></el-switch> </el-form-item> <el-form-item :prop="item.fieldIdentifier" class="el-form-item-input input-switch" style="flex:1"> <el-input v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}input${7}`]" :placeholder="item.validatorMark"></el-input> </el-form-item> <el-form-item class="el-form-item-input input-switch" style="flex:1"> <el-switch v-model="formItem[`form${formItemIndex+1}`][`${item.fieldIdentifier}switch${7}`]" active-color="#13ce66" inactive-color="#ff4949"></el-switch> </el-form-item> </div> <el-form-item v-if="parseInt(item.fieldType) === 6" :label="item.fieldName" :prop="item.fieldIdentifier" class="el-form-item-input"> <el-select v-model="formItem[`form${formItemIndex+1}`][item.fieldIdentifier]" :placeholder="item.validatorMark" multiple collapse-tags> <el-option v-for="(item,index) in creatListTest(item.selectOption)" :key="item.code" :label="item.value" :value="index" > <span style="float: left">{{ item.value }}</span> </el-option> </el-select> </el-form-item> </el-col> </el-row> </el-form> </div> </div> </div> </div> </template> <script> export default { data() { return { querySite:'', rtuCode:'', querySiteList:[], siteNameList:['遥测站设置','中心站设置','传感器型号选择','气象传感通信设置','工业相机设置','水文传感通信','从机设置', '数据滤波','水位计','雨量计','流量计','蒸发皿','土壤沉降仪','4-20mA设置','其他设置'], formAll:[], // siteNameList:[], formAllBody:[], activeIndex: '0', rules:{}, }; }, mounted() { }, methods: { echoClick(){ this.formAll=[] this.activeIndex = '0' this.initPage(this.querySite) // this.handleSelect(0) // console.log(this.activeIndex) }, temStorageEcho(){ // this.activeIndex = '0' // console.log(JSON.parse(sessionStorage.getItem(name)),111) this.formAll = JSON.parse(sessionStorage.getItem(name)) }, temStorage(){ try{ sessionStorage.setItem(name, JSON.stringify(this.formAll)); this.$message({message: `保存成功`,type: "success"}); } catch(err) { this.$message({message: err,type: "warning"}); } // localStorage.getItem(name); // console.log(sessionStorage.getItem(name),111) }, sunmitAll(){ // 提交所有表单,循环校验所有表单,当有个表单校验失败就break,提示该表单校验失败,根据校验成功总数或者无失败确定完成,组装数据发送到后台 var successCount = 0 var successFlag = false for(var i = 0; i<15;i++){ this.$refs['form'][i].validate((valid) => { if (valid) { successCount++ } else { // this.$message({message: `${this.siteNameList[i]} 校验失败,请查看`,type: "warning"}); // alert(`${this.siteNameList[i]} 校验失败,请查看`); // this.$notify({ // title: '警告', // message: `${this.siteNameList[i]} 校验失败,请查看`, // type: 'warning' // }); successFlag = true // return false; } }); // if(successFlag){ // return false // } } if(successCount === this.siteNameList.length){ this.$message({message: '表单全部校验成功',type: "success"}); }else{ // this.$message({message: `第${i}个表单校验失败,请查看`,type: "warning"}); } // 组装数据需要的属性,暂时是死值,也可以循环出来 const parmas ={ data:{ rtuCode:this.rtuCode, rtuTelemeteringStationSetting:this.formAll[0].form1, rtuCentreSetting:this.formAll[1].form2, rtuSenseTypeSetting:this.formAll[2].form3, rtuMeteorologicalSensingCommunicationSetting:this.formAll[3].form4, rtuIndustrialCameraSetting:this.formAll[4].form5, rtuHydrologicSensingCommunication:this.formAll[5].form6, rtuSlaveSetting:this.formAll[6].form7, rtuDataFilter:this.formAll[7].form8, rtuWaterLevelSetting:this.formAll[8].form9, rtuRainSetting:this.formAll[9].form10, rtuFlowmeterSetting:this.formAll[10].form11, rtuEvaporatingDishSetting :this.formAll[11].form12, rtuSoilSettler:this.formAll[12].form13, rtu4To20Setting:this.formAll[13].form14, rtuOtherSetting:this.formAll[14].form15 } } // 之前初始化时将3处的两个数组生成了需要的字段,现在需要把每处16个字段组装成两数组,删除不需要的字段,转化方法暂时写在这里 function dealInputSwitch(str='rtushuiwen_shangqingarrInt',strBool='rtushuiwen_shangqingarrboolean'){ var form6Input=[]; var form6Switch=[]; var strTarget='rtuHydrologicSensingCommunication' for(let i =0;i<8;i++){ var hasInput = parmas.data[strTarget].hasOwnProperty(`${str}input${i}`) if(hasInput){ form6Input[i]=parmas.data[strTarget][`${str}input${i}`] }else{ form6Input[i]= null } parmas.data[strTarget][str]=form6Input delete parmas.data[strTarget][`${str}input${i}`] var hasSwitch = parmas.data[strTarget].hasOwnProperty(`${str}switch${i}`) if(hasSwitch){ form6Switch[i]=parmas.data[strTarget][`${str}switch${i}`] }else{ form6Switch[i]= false } parmas.data[strTarget][strBool]=form6Switch delete parmas.data[strTarget][`${str}switch${i}`] } } dealInputSwitch('rtushuiwen_shangqingarrInt','rtushuiwen_shangqingarrboolean'); dealInputSwitch('rtushuiwen_chenjiangarrInt','rtushuiwen_chenjiangarrboolean'); dealInputSwitch('rtushuiwen_zhaweiarrInt','rtushuiwen_zhaweiarrboolean'); let rtuAddUpTimes= parmas.data['rtuTelemeteringStationSetting']['rtuAddUpTimes'].sort((item1, item2) => item1 - item2) let rtucamera_jiabao= parmas.data['rtuIndustrialCameraSetting']['rtucamera_jiabao'].sort((item1, item2) => item1 - item2) let rtuAddUpTimesNew=[] let rtucamera_jiabaoNew=[] // console.log(rtuAddUpTimes,'rtuAddUpTimes') for(var i =0;i<24;i++){ rtuAddUpTimesNew.push(0) rtucamera_jiabaoNew.push(0) } rtuAddUpTimes.forEach((item,index)=>{rtuAddUpTimesNew[item]= 1}) rtucamera_jiabao.forEach((item,index)=>{rtucamera_jiabaoNew[item]= 1}) parmas.data['rtuTelemeteringStationSetting']['rtuAddUpTimes'] = rtuAddUpTimesNew parmas.data['rtuIndustrialCameraSetting']['rtucamera_jiabao'] = rtucamera_jiabaoNew this.$http.post(`${this.nozzle.rTUSettingServiceUpdate}`,parmas).then(res=>{ // console.log(res,'rTUSettingServiceUpdate') this.echoClick() }) // console.log(parmas,'form6Inputform6Input') // this.formAll=[] // this.initPage(this.querySiteList[1]) }, creatListTest(arr){ var arrList = arr.split(',') // console.log(arrList,'arrrrrrrr') let list = arrList.map((item,index)=>{ let obj={};obj['code']=index;obj['value']=item;return obj }) return list }, creatList(arr){ // 下拉框需要的option数据,ele需要value和lable,value是点击后的字段值,lable是展示值 let list = arr.map((item,index)=>{ let obj={};obj['code']=index+1;obj['value']=item;return obj }) return list }, handleSelect(key) { this.activeIndex = key // console.log(key) for(var i = 0;i<15;i++){ if(key != i){ this.formAll[i][`form${i+1}Show`]= false }else{ this.formAll[i][`form${i+1}Show`]= true } } }, selectChange(val){ // console.log(val,'val') this.echoClick(val) }, async initPage(site){ // 回显接口请求数据 将水文传感里面3处特殊的控件需要的值,用请求数据遍历生成表单需要的字段,因为这3处的动态表单使用的是死的字段,其他的对应的表单数据赋值给对应表单就能回显了、 let resFirst = await this.$http.post(`${this.nozzle.rTUSettingServiceQueryById}?code=${site}`) let resData = resFirst.data.data let formArr=['rtuTelemeteringStationSetting','rtuCentreSetting','rtuSenseTypeSetting','rtuMeteorologicalSensingCommunicationSetting','rtuIndustrialCameraSetting','rtuHydrologicSensingCommunication', 'rtuSlaveSetting','rtuDataFilter','rtuWaterLevelSetting','rtuRainSetting','rtuFlowmeterSetting','rtuEvaporatingDishSetting','rtuSoilSettler','rtu4To20Setting','rtuOtherSetting'] // console.log(this.formAll,'ressssss') // this.formAll={} this.rtuCode = resData.rtuCode for(let i = 1;i<=15;i++){ let obj ={}; // 水文传感里是第6个表单 if(i!==6 && i!==1&& i!==5){ obj[`form${i}`]=resData[formArr[i-1]] }else if(i===1){ var formObj = Object.assign(resData[formArr[i-1]]) var rtuAddUpTimesNew=[] if(!formObj.hasOwnProperty('rtuAddUpTimes')){ return } formObj.rtuAddUpTimes.forEach((res,index)=>{ if(res===1){ rtuAddUpTimesNew.push(index) } }) // form1Obj.hasOwnProperty('rtuAddUpTimes') formObj.rtuAddUpTimes=rtuAddUpTimesNew // console.log(form1Obj,'form1Obj') obj[`form${i}`]=formObj }else if(i===5){ let formObj = Object.assign(resData[formArr[i-1]]) let rtucamera_jiabaoNew=[] if(!formObj.hasOwnProperty('rtucamera_jiabao')){ return } formObj.rtucamera_jiabao.forEach((res,index)=>{ if(res===1){ rtucamera_jiabaoNew.push(index) } }) formObj.rtucamera_jiabao=rtucamera_jiabaoNew // console.log(form1Obj,'form1Obj') obj[`form${i}`]=formObj }else if(i===6){ var form6Obj = resData[formArr[i-1]] // 每一处需要input switch各8个共16个模拟字段,只处理第6个表单 function creatInputSwitch(str,strBool){ if(form6Obj.hasOwnProperty(str)&&form6Obj.hasOwnProperty(strBool)){ for(let i=0;i<8;i++){ form6Obj[`${str}input${i}`]= form6Obj[str][i] form6Obj[`${str}switch${i}`]= form6Obj[strBool][i] } delete form6Obj[str] delete form6Obj[strBool] } } creatInputSwitch('rtushuiwen_shangqingarrInt','rtushuiwen_shangqingarrboolean'); creatInputSwitch('rtushuiwen_chenjiangarrInt','rtushuiwen_chenjiangarrboolean'); creatInputSwitch('rtushuiwen_zhaweiarrInt','rtushuiwen_zhaweiarrboolean'); obj[`form${i}`]=form6Obj } if(i!==1){ obj[`form${i}Show`]=false }else{ obj[`form${i}Show`]=true } // 表单数据赋值完成,控制表单切换的formshow,也放在一起了 this.formAll.push(obj) // console.log(this.formAll,'this.formAll') } }, validatorAll(rule, value, callback,type,sug,alart){ let typeLocal = type; let sugLocal = sug; let alartLocal = alart; // 数字范围、数字长度、字符串长度、正则等 if(value&&parseInt(typeLocal) === 1){ // 数字范围 if(value !== undefined){ let sug1=parseInt(sugLocal.split(',')[0]) let sug2=parseInt(sugLocal.split(',')[1]) if(sug1<=value && value<=sug2){callback()}else{callback(new Error(alartLocal))} }else{ callback() } }else if(value&&parseInt(typeLocal) === 2 &&sugLocal){ // 正则 let regExp =sugLocal.slice(1,-1) let reg = new RegExp(regExp) if(reg.test(value)){ callback() }else{ callback(new Error(alartLocal)) } }else if(value&&parseInt(typeLocal) === 3){ if(sugLocal === undefined || sugLocal === ''){ // 下拉框 不显示错误信息 callback() }else{ // console.log(value,sugLocal.indexOf(','),'value') if(sugLocal.indexOf(',') !== -1){ // 带,的是范围,不带则是固定长度 let sug1=parseInt(sugLocal.split(',')[0]) let sug2=parseInt(sugLocal.split(',')[1]) if(value.length >=sug1 && value.length <=sug2){callback()}else{callback(new Error(alartLocal))} }else if(sugLocal.indexOf(',') === -1){ // console.log(sugLocal.indexOf(','),parseInt(sugLocal)) if(value.length === parseInt(sugLocal)){callback()}else{callback(new Error(alartLocal))} } } }else if(value&&parseInt(typeLocal) === 4){ if(sugLocal === undefined || sugLocal === ''){ callback() }else{ let sug1=parseInt(sugLocal.split(',')[0]) let sug2=parseInt(sugLocal.split(',')[1]) if(sug1<=value && value<=sug2){callback()}else{callback(new Error(alartLocal))} } }else if(value&&parseInt(typeLocal) === 5){ // console.log(value,'value') if(typeof value !== 'number'){ callback(new Error('请输入纯数字')) }else{ let sug1=parseInt(sugLocal.split(',')[0]) let sug2=parseInt(sugLocal.split(',')[1]) if(sug1<=value && value<=sug2){callback()}else{callback(new Error(alartLocal))} } }else{callback()} }, formControl(){ function uniq(array){ var temp = []; //一个新的临时数组 for(var i = 0; i < array.length; i++){ if(temp.indexOf(array[i]) == -1){ temp.push(array[i]); } } return temp; } // 生成表单控件的接口 this.$http.post(this.nozzle.rtuPageQueryPage).then(res=>{ var dataRes = res.data.data // console.log(dataRes,'dataRes') for(var i in dataRes){ if(dataRes[i].length !==0){ dataRes[i].forEach((item,index,arr) =>{ this.rules[item.fieldIdentifier] = [{ validator: (rule, value, callback)=>{this.validatorAll(rule, value, callback,item.validatorType,item.validatorRules,item.validatorErrorText)}, trigger: 'change' }] }) let sub_titleList = dataRes[i].map(item=>{ return item.subTitle }) var newObj =[] // 根据小标题去重 uniq(sub_titleList).forEach(item=>{ var obj={name:item,data:[]} var data = dataRes[i].forEach(l=>{ if(l.subTitle === item && l.subTitle!=='' &&l.subTitle!==undefined){ obj.data.push(l) }else if(l.subTitle==='' || l.subTitle===undefined){ obj.data.push(l) } }) if(obj.name ===undefined){ return } // obj.data= data 将后台数据生成带有小标题的 newObj.push(obj) }) this.$set(this.formAllBody,i,newObj) } } }) }, async getSiteList(){ await this.$http.post(this.nozzle.rTUSettingServiceQueryList).then(res=>{ // console.log(res.data.data,'resss') this.querySiteList = res.data.data }) } }, created(){ this.getSiteList().then(res=>{ this.initPage(this.querySiteList[0]); }); this.formControl(); }, // beforeRouteLeave (to, from, next) { // // 导航离开该组件的对应路由时调用 // // 可以访问组件实例 `this` // this.$confirm("请检查是否需要暂存!", "提示", { // confirmButtonText: "已暂存", // cancelButtonText: "取消", // type: "warning" // }).then(res=>{ next() }).catch(() => {}); // } }; </script> <style scoped> #content{ width: 100% !important; height: 100% !important; } #navMenuContent { /* height: calc(100% - 20px); width: calc(100% - 20px); float: left; border: 1px solid aqua; box-sizing: border-box; margin: 10px; position: relative; */ width: 100% !important; /* background-color: #fff; */ } .switchContent{ color: rgb(99, 96, 96); /* background-color: #fff; */ /* background-color: #fff; */ padding: 2% !important; } /deep/.el-form-item { /* color: red!important; */ } .el-menu-item.is-active{ background-color: #fff !important; } .el-menu-item:hover{ background-color: #fff !important; } /deep/.el-form-item__content .el-input .el-input__inner{ color: black !important; } /deep/.el-form-item__content i{ font-style:normal !important; padding-right: 5px !important; } .el-form-item, .el-form-item-input{ margin:11px 0 11px 0 !important; } /deep/.rowClass .subTitle{ /* height:40px!important; */ line-height:51px !important; color:aqua !important; /* margin-top: 11px; */ } /deep/.el-col .input-switch .el-form-item-input{ /* display: flex; */ margin: initial !important; } /deep/.rowClass .el-col{ height: 51px !important; } /deep/.form-switch .el-form-item__label{ width: 180px !important; } /deep/.form-switch .el-form-item__content{ width: 150px !important; margin-left: 150px !important; } /deep/.input-switch .el-form-item__content{ margin-left: 0 !important; } /deep/.rowClass .el-form-item__label{ /* line-height: initial; */ } .input-switch-div{ position:absolute !important; left:0 !important; top:0 !important; width:1000px !important; display:flex !important; } /deep/.el-col .input-switch-div .el-form-item__content{ width: 66px !important } </style>