vxe-table,二级菜单展开设置背景颜色

业务场景

昨天产品小姐姐告诉老王,列表数据增加二级列表,跟服务端沟通后得知,二级列表数据根据一级列表数据动态调用接口查询获取。查找vxe-table api得知,vxe-table 设置 tree-config、toggle-tree-expand,vxe-table-column添加 tree-node
特别提醒:vxe-table版本2.x
业务代码如下缩略版:

<template>
  <div class="div_main_content">
    <div class="table-box">
      <vxe-table
        resizable
        show-footer
        show-overflow
        height="100%"
        ref="mainTable"
        :data="tableData"
        :auto-resize="true"
        show-footer-overflow
        show-header-overflow
        highlight-hover-row
        highlight-current-row
        :tree-config="treeConfig"
        @toggle-tree-expand="toggleTreeExpand"
      >
        <vxe-table-column title="" width="60" fixed="left" tree-node> </vxe-table-column>
        <!-- 其他列配置代码省略... -->
      </vxe-table>
    </div>
  </div>
</template>

<script>
import { getSalesList, salesStatisticsSub } from '@/axios/api.js';

export default {
  name: 'SalesStat',
  data() {
    return {
      tableData: [],
      /** 一级行id */
      currentRowId: '',
      /** 一级行id对应的二级菜单数据 */
      childNodeData: [],
      /** 存储一级行id对应的二级菜单总数 */
      cacheMap: new Map(),
    };
  },
  computed: {
    treeConfig() {
      return {
        children: 'children',
        lazy: true,
        line: false,
        trigger: 'default',
        loadMethod: this.loadMethod,
      };
    },
  },
  watch: {
    childNodeData(children) {
      const subNodeCount = children.length;
      this.cacheMap.set(this.currentRowId, subNodeCount);
      setTimeout(() => {
        const targetRows = document.querySelectorAll(`tr[rowid=${this.currentRowId}]`);
        this.setChildrenClassName(targetRows[0], subNodeCount);
        this.setChildrenClassName(targetRows[1], subNodeCount);
      }, 0);
    },
  },
  methods: {
    // 设置二级列表类名
    setChildrenClassName(rowNode, count) {
      if (!rowNode) {
        return;
      }

      rowNode.classList.add('row-selected-parent');
      let next = count;
      let nextRowNode = rowNode.nextElementSibling;
      while (next > 0) {
        nextRowNode.classList.add('row-selected-son');
        nextRowNode = nextRowNode.nextElementSibling;
        next--;
      }
    },
    toggleTreeExpand({ expanded, row }) {
      const children = row.children;
      this.currentRowId = this.$refs.mainTable.getRowid(row);

      if (children && expanded) {
        const subNodeCount = this.cacheMap.get(this.currentRowId);
        setTimeout(() => {
          const targetRows = document.querySelectorAll(`tr[rowid=${this.currentRowId}]`);
          this.setChildrenClassName(targetRows[0], subNodeCount);
          this.setChildrenClassName(targetRows[1], subNodeCount);
        }, 0);
      }
    },
    // 一级列表数据
    async getTableData() {
      this.cacheMap.clear();
      const res = await getSalesList();
      if (res.code === 200) {
        this.tableData = res.data;
      }
    },
    // 二级列表
    loadMethod({ row }) {
      const param = { id: row.id };
      return new Promise((resolve) => {
        // api接口
        salesStatisticsSub(param).then((res) => {
          resolve(res.data);
          this.childNodeData = JSON.parse(JSON.stringify(res.data));
        });
      });
    },
  },
};
</script>

<style lang="scss" scoped>
.table-box {
  >>> .row-selected-parent {
    background-color: rgba(0, 110, 255, 0.06) !important;
  }
  >>> .row-selected-son {
    background-color: rgba(0, 110, 255, 0.03) !important;
  }
}
</style>

最终实现效果图

vxe-table二级菜单展开设置背景颜色.gif

实现原理

根据当前点击的行idrowId,调用接口查询该行对应的二级列表个数subNodeCount,由于二级列表直接插入到当前行的下一行,因此可以通过const targetRows = document.querySelectorAll(tr[rowid=${rowId}]);
查询到当前行元素,结合subNodeCount,循环调用let nextRowNode = rowNode.nextElementSibling;设置二级行类名。

  1. 由于document.querySelectorAll查询的是某一刻的静态节点,无法查询到动态插入后的节点。因此把节点查询放到setTimeout下一个周期的轮询。
  2. 第一次调用接口查询二级列表时,触发toggleTreeExpand时,无法获取到row.children个数,因为在查询接口的过程中已经触发了该事件。因此通过watch去监听二级列表的结果,再查询当前点击行元素,添加类名row-selected-parent,以及分别给二级列表元素添加类名row-selected-son
  3. 由于调用某行的二级查询列表后,再次展开及收起时,无法触发查询二级列表的接口,因此需要把当前行对应的二级列表个数subNodeCount存储下来,通过cacheMap来进行存储及获取,下次展开时重新给一级列表和二级列表添加类名。

马后炮

  1. 突然的某一天,我的一个同事跟我说,vxe-table二级菜单展开设置背景颜色,有API的,经过仔细查阅确实如此,害得我绞尽脑汁儿又掉了2根头发。哎,发量减少。
  2. 设置row行样式:官方API参考链接
  3. 具体实现方式如下:
       <vxe-table
          border
          :row-class-name="rowClassName"
          :data="tableData">
          <vxe-table-column type="seq" width="60"></vxe-table-column>
          <vxe-table-column field="name" title="Name"></vxe-table-column>
          <vxe-table-column field="sex" title="Sex"></vxe-table-column>
          <vxe-table-column field="age" title="Age"></vxe-table-column>
          <vxe-table-column field="attr1" title="Attr1"></vxe-table-column>
          <vxe-table-column field="address" title="Address" show-overflow></vxe-table-column>
        </vxe-table>
methods: {
  rowClassName ({ row }) {
       if (row.hasRowGreen) {
            return 'row-green';
         }
  },
}
  1. 实现原理是:对于某些想要添加背景颜色的行,在调用接口拿到数据后,给每条想要设置背景颜色的数据,添加自定义属性,比如 item.hasRowGreen = true;某行有这个属性的row会添加上自定义类型 row-green,在style中定义好类名对应的背景颜色即可。perfect,完美解决!
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352

推荐阅读更多精彩内容