当前位置: 首页 > news >正文

高端网站建设收费为何比较贵查询商标注册的官方网

高端网站建设收费为何比较贵,查询商标注册的官方网,卫浴响应式外贸网站建设,如何快速做企业网站包括商城需求#xff1a;点击左边的tab页签#xff0c;请求右侧表格数据#xff1b;如果返回的接口数据存在taskuser字段并不为null#xff0c;那么按照这个字段去回勾数据。如果存在数据#xff0c;但与后面所勾选的数据项不同#xff0c;按照后面勾选的为主。 el-tabs tab-…需求点击左边的tab页签请求右侧表格数据如果返回的接口数据存在taskuser字段并不为null那么按照这个字段去回勾数据。如果存在数据但与后面所勾选的数据项不同按照后面勾选的为主。 el-tabs tab-positionleft v-modeldialogInfo.activeTab styleheight: 350px classdemo-tabs tab-changetabChangeel-tab-pane v-fortab in dialogInfo.tabs :keytab.id :labeltab.text :nametab.textdiv classtableDivel-tablerefrefTableV:datatableConfig.tableData:header-cell-style{ background: #F5F7FA, height: 30px }stylewidth: 100%; margin: 0 autoheight100%aligncenterrow-keyempNamestripeborderselectselectel-table-column typeselection width40 fixed label操作 /el-table-column fixed propuserName label用户编号 width120 aligncenter /el-table-column fixed propempName label用户姓名 min-width150 aligncenter /el-table-column fixed propexpiresdate label过期日期 min-width150 aligncentertemplate v-slotscopeel-date-pickerv-ifdialogInfo.tabs[dialogInfo.activeTabIndex].allot?.empName scope.row.empNamev-modelscope.row.expiresdatetypedateplaceholder选择日期sizesmallchangehandleDateChange(scope.row)value-formatYYYY-MM-DD/span v-else clickchangeLeader(scope.row){{ scope.row.expiresdate || }}/span/template/el-table-columnel-table-column fixed propleaderNames label直接领导 min-width150 aligncentertemplate v-slotscopespan v-ifscope.row.leaderNames scope.row.leaderNames ! sizesmall clickleaderSearch(scope.row){{ scope.row.leaderNames || 选择领导 }}/spanspan v-else-ifdialogInfo.tabs[dialogInfo.activeTabIndex].allot?.empName scope.row.empNameel-button sizesmall clickleaderSearch(scope.row){{ 选择领导 }}/el-button/span/template/el-table-column/el-table/div/el-tab-pane/el-tabs const refTableV ref(null) //表格 const refTree ref(null) const dialogInfo reactive({tabs: [],dialogText: 任务分配,dialogFormVisible: false,activeTab: ,searchstrId: ,list: [],treeLearder: {},str: [] })const tableConfig reactive({allot: {},tableData: [],loading: false,page: 1,selectedData: [], // 存储当前勾选的数据项lastSelectedRow: {},paramsData: {},activeTabIndex: 0 }) 首先openInit 这个方法是我打开弹层的第一步tabs数据是左侧的角色信息我会给每一项的tab数据添加selectedData和allot 这个在后面取值会用到。 const openInit (list) {dialogInfo.str []list.forEach((item) dialogInfo.str.push(item.factory , item.materialscode))tableConfig.selectedData [] // 存储当前勾选的数据项tableConfig.lastSelectedRow {}tableConfig.allot {}dialogInfo.list JSON.parse(JSON.stringify(list))dialogInfo.treeLearder {}getPropertyList({searchstr: {taskType: SPAREPARTSTASKROLE}}).then((res) {const tabs res.data.rows || []dialogInfo.searchstrId if (tabs.length 0) {dialogInfo.searchstrId tabs[0].iddialogInfo.activeTab tabs[0].texttabs.forEach((row) {row.selectedData []row.allot {}})dialogInfo.tabs tabsdialogInfo.activeTabIndex 0dialogInfo.dialogFormVisible truegetTable() // 获取表格数据}}) }const getTable () {preTaskAssign({searchstr: {id: dialogInfo.searchstrId,eventcodes: dialogInfo.str.join(;)}}).then((res) {const tableData res.data.row?.teapSysUserEntityList || []const taskuser res.data.row?.taskuser || refTableV.value[dialogInfo.activeTabIndex].clearSelection()const strLength dialogInfo.str.lengthif (strLength 1) {if (tableData tableData.length 0) {tableData.forEach((newRow) {if (newRow.userName taskuser) {dialogInfo.tabs[dialogInfo.activeTabIndex].selectedData [newRow]dialogInfo.tabs[dialogInfo.activeTabIndex].allot newRownextTick(() {refTableV.value[dialogInfo.activeTabIndex].toggleRowSelection(newRow, true)})}})}}tableConfig.tableData tableData}) } 代码主要就是针对勾选数据 保存数据切换tab页签 再次回来后数据的勾选处理  const select (selectedRows) {// 获取当前 tab 的数据const currentTab dialogInfo.tabs[dialogInfo.activeTabIndex]refTableV.value[dialogInfo.activeTabIndex].clearSelection()// 清空上一次选中的数据currentTab.selectedData []currentTab.allot {}// 更新当前 tab 的 selectedData 和 allotif (selectedRows.length 1) {currentTab.selectedData selectedRowscurrentTab.allot selectedRows[0] // 如果有 allot 数据更新为第一个选中的数据nextTick(() {refTableV.value[dialogInfo.activeTabIndex].toggleRowSelection(currentTab.allot, true)})} else {ElMessage.warning(只能选择一条数据,请取消已勾选项后再进行选择)}// 更新当前 tab 的 selectedData 和 allotdialogInfo.tabs[dialogInfo.activeTabIndex] currentTab }// 选择领导的弹层 const tabChange (name) {// 查找当前 tab 索引dialogInfo.activeTab namedialogInfo.searchstrId dialogInfo.tabs.find((item) item.text name).idlet index nulldialogInfo.tabs.some((item, ind) {if (item.text name) {index indreturn true // 找到就停止遍历}return false})dialogInfo.activeTabIndex indexconst currentTab dialogInfo.tabs[index]// 保存当前勾选状态const { selectedData, allot } currentTab// 在切换 tab 时将勾选状态存储到 dialogInfo 中dialogInfo.tabs[index].selectedData selectedData || []dialogInfo.tabs[index].allot allot || {}// 重新加载当前 tab 的数据保持选中状态preTaskAssign({searchstr: {id: dialogInfo.searchstrId,eventcodes: dialogInfo.str.join(;) // 外面行勾选的数据 工厂加物料编号传字符串}}).then((res) {// 获取从接口返回的表格数据const tableDataList res.data.row?.teapSysUserEntityList || []const taskuser res.data.row?.taskuser || // 更新表格数据tableConfig.tableData tableDataListrefTableV.value[dialogInfo.activeTabIndex].clearSelection()// 使用一些逻辑优化遍历找到合适的行就停止let isFound falsetableDataList.forEach((row) {if (isFound) return // 如果已经找到匹配项直接跳过后续行const selectedUserName selectedData[0]?.userNameif (taskuser) {if (selectedData.length 0) {// 1. 如果有taskuser但是selectedData为空依照taskuser去筛选数据if (row.userName taskuser) {dialogInfo.tabs[dialogInfo.activeTabIndex].selectedData [row]dialogInfo.tabs[dialogInfo.activeTabIndex].allot rownextTick(() {refTableV.value[dialogInfo.activeTabIndex].toggleRowSelection(row, true)})isFound true // 标记为已找到匹配项跳出循环}} else if (selectedUserName ! taskuser) {// 2. 如果同时存在但是匹配不上那么按照selectedData中的数据去筛选if (row.userName selectedUserName) {dialogInfo.tabs[dialogInfo.activeTabIndex].selectedData [row]dialogInfo.tabs[dialogInfo.activeTabIndex].allot rownextTick(() {refTableV.value[dialogInfo.activeTabIndex].toggleRowSelection(row, true)})isFound true // 标记为已找到匹配项跳出循环}} else if (selectedUserName taskuser) {// 3. 如果同时存在匹配的上按照taskuser判断nextTick(() {const selectedRow dialogInfo.tabs[dialogInfo.activeTabIndex].selectedData[0]refTableV.value[dialogInfo.activeTabIndex].toggleRowSelection(selectedRow, true)})isFound true // 标记为已找到匹配项跳出循环}} else {// 4. taskuser不存在按照selectedData去筛选if (row.userName selectedUserName) {dialogInfo.tabs[dialogInfo.activeTabIndex].selectedData [row]dialogInfo.tabs[dialogInfo.activeTabIndex].allot rownextTick(() {refTableV.value[dialogInfo.activeTabIndex].toggleRowSelection(row, true)})isFound true // 标记为已找到匹配项跳出循环}}})}) }const leaderSearch (row) {// 查找与勾选行对应的数据const exObj tableConfig.tableData.find((item) item.userId dialogInfo.tabs[dialogInfo.activeTabIndex].allot.userId)// 检查过期日期是否为空if (exObj.expiresdate || exObj.expiresdate null) return ElMessage.warning(请先设置时间)const str dialogInfo.tabs[dialogInfo.activeTabIndex].id // 这个就是左边角色的idrefTree.value.openInit(JSON.parse(JSON.stringify(row)), str) }
http://www.lakalapos1.cn/news/11523/

相关文章:

  • 做cms网站擦边球网站做国内还是国外好
  • 网站营销单页怎么设计方案阿里云建设网站
  • 中小型企业网站建设与管理汕头网站备案
  • 东莞网站建设案例效果好网站建设哪家好
  • 论文 网站建设一体化企业管理软件
  • 乌兰浩特市建设局网站牛商网网站源码
  • 做网站的像素重庆网站自己推广
  • 白领兼职做网站网站互点联盟
  • 网站名称是否已被注册企业推广产品有什么平台好
  • struts2 做的网站网站建设需求分析写什么
  • 建设银行镇海支行网站国内比较好的猎头公司
  • 大兴区网站建设WordPress更该主题
  • 网站的域名都有哪些网站标题在线制作
  • 信阳网站建设公司汉狮排名wordpress子主题空白
  • 思维导图在线制作网站即时通讯软件
  • 龙岗网站建设方案门户网站建设基础术语
  • 拼多多网站的类型潍坊网站建设培训
  • 域名主机网站导航广告设计公司简介文案
  • 装饰公司做网站宣传的是个好处建筑专业律师事务所
  • 织梦 调用网站地址自适应网站制作简创网络
  • 网站备案号填写做展示型网站便宜吗
  • 礼品公司网站模板软件代理网
  • 郑州营销型网站制作运营html电影网站模板
  • 建筑公司网站设计北京到安阳高铁
  • vps网站管理助手软件公司门户网站模板
  • 大庆建设大厦网站做高清视频的网站
  • ps响应式网站设计尺寸企业域名多少钱
  • 企业网站建设的可行性分析哪个网站做图片外链
  • 武进建设银行网站首页wordpress主题hestia
  • 网站中下拉列表框怎么做中国建设银行手机银行下载