管道基础大数据平台系统开发-【前端】-新系統界面
Surpriseplus
2023-04-11 78ab9cd3f487cc271ea5b3a10cb9d2491b78767e
src/views/datamanage/dictionaryManage.vue
@@ -18,14 +18,19 @@
          :placeholder="$t('shuJuGuanLi.shuJuJianSuo.valueone')"
          suffix-icon="el-icon-search"
        ></el-input>
        <el-tree
          :data="domainData"
          :props="defaultProps"
        >
        </el-tree>
        <!-- <el-tree
          :data="domainData"
          :props="defaultProps"
          @node-click="getTableDesc"
          :filter-node-method="filterNode"
          ref="tree"
        ></el-tree>
        ></el-tree> -->
        <!-- <ul>
          <li
            @click="getTableDesc(item)"
@@ -574,6 +579,10 @@
  insertDict,
} from "../../api/api";
import MyBread from "../../components/MyBread.vue";
import { conditions } from '../Archive/Archive';
import {
  getTreeData
} from "../../utils/treeData.js"
export default {
  name: "dictionaryManage",
  components: { MyBread },
@@ -611,7 +620,7 @@
      domainData: [],
      defaultProps: {
        children: "children",
        label: "val",
        label: "label",
      },
    };
  },
@@ -757,7 +766,7 @@
      var m = time.getMonth() + 1;
      var d = time.getDate();
      var h = time.getHours();
      var mm = time.getMinutes();
      var mm = time.getMvinutes();
      var s = time.getSeconds();
      return y + "-" + this.add0(m) + "-" + this.add0(d);
    },
@@ -769,59 +778,67 @@
      this.formInline.tab = null;
      this.getSelectDictTab();
    },
    treeData(source) {
      let cloneData = JSON.parse(JSON.stringify(source));// 对源数据深度克隆
      if (cloneData.length != 0) {
        return cloneData.filter((father) => {
          // 循环所有项
          let branchArr = cloneData.filter((child) => father.label == child.pname); // 对比ID,分别上下级菜单,并返回数据
          branchArr.length > 0 ? (father.children = branchArr) : ''; // 给父级添加一个children属性,并赋值
          // 属于同一对象问题,例如:令 a=b、c=1 ,然后再令 b.c=c , 那么 a.c=b.c=c=1 ;同理,后续令 c.d=2 ,那么 a.c.d 也是=2;
          // 由此循环多次后,就能形成相应的树形数据结构
          return father.pname == -1; // 返回一级菜单
        });
      }
    },
    //目录树获取
    async getSelectDictTab() {
      const data = await selectDictTab({ name: this.formInline.tab });
      if (data.code != 200) {
        this.$message.error("下拉调用失败");
        this.$message.error("列表调用失败");
      }
      var val = data.result;
      var std = [];
      val.filter((item) => {
        if (std.indexOf(item.bak) == -1) {
          std.push(item.bak);
          this.domainData.push(
            {
              val: item.bak,
              children: [],
            }
          )
        }
      });
      this.domainData.filter((item) => {
        val.filter((res) => {
          if (item.val === res.bak) {
            res.val = res.tabDesc
            item.children.push(res)
      var val = JSON.parse(JSON.stringify(data.result));
      var tree = getTreeData(data.result);
      this.domainData = tree
      this.getQueryNameData(tree[0]);
      // var = this.domainData[0].children;
      //
    },
    getQueryNameData(res) {
      if (res.children) {
        this.getQueryNameData(res.children);
      } else {
        if (res.length != 1) {
          if (res[0].children) {
            this.getQueryNameData(res[0].children);
          } else {
            var result = res[0]
            this.insertform.tab = result.tab;
            this.insertform.tabDesc = result.tabDesc;
            this.insertform.ns = result.ns;
            this.listData.tab = result.tab;
            this.listData.ns = result.ns;
            this.activeName = result.tab;
            this.startQueryNameData();
          }
        })
      })
      // let bdres = data.result.filter((item) => item.ns == "bd");
      // let bsres = data.result.filter((item) => item.ns == "bs");
      // let mdres = data.result.filter((item) => item.ns == "md");
      // for (var i in bdres) {
      //   // bdres[i].val = bdres[i].tabDesc + '(' + bdres[i].tab + ')';
      //   bdres[i].val = bdres[i].tabDesc;
      // }
      // for (var i in bsres) {
      //   // bsres[i].val = bsres[i].tabDesc + '(' + bsres[i].tab + ')';
      //   bsres[i].val = bsres[i].tabDesc;
      // }
      // for (var i in mdres) {
      //   // bsres[i].val = bsres[i].tabDesc + '(' + bsres[i].tab + ')';
      //   mdres[i].val = mdres[i].tabDesc;
      // }
      // this.domainData[0].children = bdres;
      // this.domainData[1].children = bsres;
      // this.domainData[2].children = mdres;
      var result = this.domainData[0].children;
      this.insertform.tab = result[0].tab;
      this.insertform.tabDesc = result[0].tabDesc;
      this.insertform.ns = result[0].ns;
      this.listData.tab = result[0].tab;
      this.listData.ns = result[0].ns;
      this.activeName = result[0].tab;
      this.startQueryNameData();
        } else {
          if (res.children) {
            this.getQueryNameData(res.children);
          } else {
            var result = res
            this.insertform.tab = result.tab;
            this.insertform.tabDesc = result.tabDesc;
            this.insertform.ns = result.ns;
            this.listData.tab = result.tab;
            this.listData.ns = result.ns;
            this.activeName = result.tab;
            this.startQueryNameData();
          }
        }
      }
    },
    handleClose() {
      this.$confirm("关闭后无法保存,是否关闭?")