qx
qx
2025-04-14 5350514e716d3383fa3923a007fecac5b1ea365a
src/views/hosp/project/index.vue
@@ -14,19 +14,9 @@
        </div>
        <div class="scrollable-container">
          <div class="content">
            <el-tree
              :data="deptOptions"
              :props="defaultProps"
              :expand-on-click-node="false"
              :filter-node-method="filterNode"
              ref="tree1"
              node-key="id"
              :default-expanded-keys="treeId"
              highlight-current
              @node-click="handleNodeClick"
              :render-content="renderContent"
              v-loading="loadings"
            />
            <el-tree :data="deptOptions" :props="defaultProps" :expand-on-click-node="false"
              :filter-node-method="filterNode" ref="tree" node-key="id" :default-expanded-keys="treeId"
              highlight-current @node-click="handleNodeClick" :render-content="renderContent" v-loading="loadings" />
          </div>
        </div>
      </el-col>
@@ -216,13 +206,7 @@
            width="90px"
          >
          </el-table-column>
          <el-table-column
            label="Lis项目名称"
            align="center"
            prop="lisXmmc"
            :show-overflow-tooltip="true"
            width="200px"
          >
          <el-table-column label="Lis项目名称" align="center" prop="lisXmmc" :show-overflow-tooltip="true" width="200px">
          </el-table-column>
          <el-table-column
            label="Lis编码"
@@ -1131,18 +1115,23 @@
  },
  methods: {
    debounceFilter: debounce(function (val) {
      this.$refs.tree1.filter(val);
    }, 300),
      this.$refs.tree.filter(val);
    }, 800),
    precomputePinyin() {
      const traverse = (nodes) => {
        nodes.forEach((node) => {
          if (node.label) {
            const lowerSpell = node.label.spell("low", "array").join("");
            const upperSpell = node.label.spell("up", "array").join("");
            const lowerSpell = cnchar.spell(node.label, 'low', 'array').join(''); // 完整小写拼音
            const upperSpell = cnchar.spell(node.label, 'up', 'array').join('');  // 完整大写拼音
            const shortPinyin = node.label
              .split('')
              .map(char => cnchar.spell(char, 'array')[0]?.[0]?.toLowerCase() || char) // 拼音首字母
              .join('');
            this.pinyinCache.set(node.id, {
              lowerSpell,
              upperSpell,
              label: node.label,
              shortPinyin, // 缓存拼音简写
              label: node.label
            });
          }
          if (node.children) traverse(node.children);
@@ -1153,11 +1142,12 @@
    filterNode(value, data) {
      if (!value) return true;
      const cached = this.pinyinCache.get(data.id);
      if (!cached) return false;
      if (!cached) return false; // 如果没有缓存数据,不显示该节点
      const searchLower = value.toLowerCase(); // 将搜索词转为小写
      return (
        cached.label.includes(value) ||
        cached.lowerSpell.includes(value) ||
        cached.upperSpell.includes(value)
        cached.label.includes(value) ||           // 直接匹配汉字
        cached.shortPinyin.includes(searchLower) || // 匹配拼音简写
        cached.lowerSpell.includes(searchLower)   // 匹配完整拼音
      );
    },
    filterNode2(value, data) {
@@ -1275,8 +1265,8 @@
            this.open = true;
          } else if (this.treeDate.id) {
            if (this.treeDate.qf == "0") {
              this.form.proParentId = "0";
              this.form.deptId = this.treeDate.id;
              this.form.proParentId = "0"
              this.form.deptId = this.treeDate.id
            } else {
              this.form.proParentId = this.treeDate.id;
              this.projectOptions.forEach((item) => {
@@ -1288,9 +1278,10 @@
              });
            }
            this.open = true;
          } else {
            this.form.proParentId = "0";
            this.form.proParentId = "0"
            this.open = true;
          }
        }