王多静

这里是我的记事本

导航

element的展开收起,合并表格

 

 

如果两个因为后台接口只能提供两个接口,假数据做法如下

// 什么管理 - 品牌方(采购商什么)
<template>
  <div class="purchaseOrder">
    <!--展开行table-->
    <el-table
      ref="boxData"
      v-loading="loading"
      size="small"
      :data="boxData"
      tooltip-effect="dark"
      style="width: 100%"
      max-height="600"
      @expand-change="expandChange"
    >
      <el-table-column type="expand">
        <template slot-scope="props">
          <!-- 子table -->
          <el-table
            size="small"
            :data="props.row.sonData"
            :cell-style="{ background: '#fff' }"
            style="width: 100%"
            border
            stripe
            max-height="600"
            :span-method="objectSpanMethod"
          >
            <el-table-column
              v-for="(item, index) in column2"
              :key="index"
              :label="item.title"
              :prop="item.key"
              align="center"
              :fixed="item.fixed"
              :min-width="item.width ? item.width : 120"
            >
              <template slot-scope="scope">
                <div v-if="item.key == 'handle_btn2'">
                  <el-button>操作按钮</el-button>
                </div>
                <div v-else>{{ scope.row[item.key] }}</div>
              </template>
            </el-table-column>
          </el-table>
        </template>
      </el-table-column>
      <!-- 总table -->
      <el-table-column
        v-for="(item, index) in column1"
        :key="index"
        :label="item.title"
        :prop="item.key"
        align="center"
        :fixed="item.fixed"
        :min-width="item.width ? item.width : 120"
      >
        <template slot-scope="scope">
          <div v-if="item.key == 'company_name'">
            <span class="cBlue pointer" @click="handleSee(scope.row, 'see')">{{
              scope.row.company_name
            }}</span>
          </div>
          <div v-else-if="item.key == 'is_usable'">
            <span>{{
              scope.row.is_usable == 0
                ? "禁用"
                : scope.row.is_usable == 1
                ? "启用"
                : ""
            }}</span>
          </div>
          <div v-else-if="item.key == 'handle_btn'">
            <el-button type="text" @click="handleBtn(scope.row, 'edit')"
              >修改</el-button
            >
            <el-button
              v-if="scope.row.is_usable == 1"
              type="text"
              @click="handleIsUsable(scope.row, 0)"
              >禁用</el-button
            >
            <el-button
              v-if="scope.row.is_usable == 0"
              type="text"
              @click="handleIsUsable(scope.row, 1)"
              >启用</el-button
            >
          </div>
          <div v-else>{{ scope.row[item.key] }}</div>
        </template>
      </el-table-column>
    </el-table>
  </div>
</template>
<script>
// import paging from "@/components/pages/pagination.vue";

export default {
  components: {
    // paging // 分页
  },
  data() {
    return {
      // 加载
      loading: true,
      // 表格数据
      boxData: [],
      sonData: [],
      tableHeight: 300,
      // 表格数据
      column1: [
        { title: "什么编号", key: "order_code", width: 120 },
        { title: "什么日期", key: "created_at", width: 90 },
        { title: "名称", key: "plan_name", width: 90 },
        { title: "操作", key: "handle_btn", width: 90 }
      ],
      column2: [
        { title: "品牌", key: "brand_name", width: 120 },
        { title: "产成品名称", key: "product_name", width: 90 },
        { title: "目录", key: "index", width: 90 },
        { title: "规格", key: "order_code", width: 90 },
        { title: "尺寸", key: "product_name", width: 90 },
        { title: "操作", key: "handle_btn2", width: 90 }
      ]
    };
  },

  computed: {},
  watch: {},

  mounted() {},

  created() {
    // 初始化 表格数据默认渲染
    this.handleSeach();

    // 实时屏幕高度
    let clientHeight = document.documentElement.clientHeight;
    this.tableHeight =
      clientHeight > 400 ? clientHeight - 330 : this.tableHeight;
  },

  methods: {
    // 点击搜索
    handleSeach() {
      // // 页码初始化
      // this.paging = {
      //   page: 1,
      //   limit: 10
      // };
      // this.loading = true;
      this.handleGetTable();
    },

    // 获取数据
    handleGetTable() {
      // // 接口获取数据
      // Api.customerList(param)
      //   .then(res => {
      //     const { code, data, msg, total } = res.data;
      //     this.total = total;

      this.loading = false;

      // 第一层假数据
      this.boxData = [
        { order_code: "111", plan_name: "什么名称" },
        { order_code: "2312222", plan_name: "什么名称" },
        { order_code: "32312222", plan_name: "什么名称" }
      ];

      // 给个空数组
      this.boxData.forEach((item, index) => {
        item.sonData = [];
      });
      // this.boxData = data;
      // 处理数据
      // this.handleData();
      // })
      // .catch(error => {
      //   this.loading = false;
      //   this.boxData = [];
      // });
    },

    // 处理数据
    expandChange(row, expandedRows) {
      // console.log(row, expandedRows, "点击展开push给boxData");
      // 接口获取里面数据
      this.sonData = [];
      this.sonData = [
        {
          order_code: "111",
          created_at: "2013-10-31",
          plan_name: "什么名称",
          materials: [
            {
              brand_name: "仁和",
              product_name: "产成品名称1"
            },
            {
              brand_name: "仁和",
              product_name: "产成品名称2"
            }
          ]
        },
        {
          order_code: "2312222",
          created_at: "2021-10-31",
          plan_name: "什么名称2",
          materials: [
            {
              brand_name: "仁和2",
              product_name: "产成品名称21"
            }
          ]
        },
        {
          order_code: "32312222",
          created_at: "2021-08-31",
          plan_name: "什么名称3",
          materials: [
            {
              brand_name: "仁和31",
              product_name: "产3成品名称31"
            },
            {
              brand_name: "仁和32",
              product_name: "产成品名称34"
            },
            {
              brand_name: "仁和33",
              product_name: "产成品名称31"
            }
          ]
        }
      ];

      // 先把二纬数组改成一位数组
      const handleData = [];
      if (this.sonData.length) {
        this.sonData.forEach(row => {
          // 处理company_users数组的每一个对象
          let handleItemData = Object.assign({}, row);
          if (row.materials.length) {
            row.materials.forEach((ele, index) => {
              // 新增行录字段
              ele.index = index + 1;
              // 合为新对象
              handleItemData = Object.assign({}, handleItemData, ele);
              // 需要合并的条数 加一个新属性:合并的个数mergeNum, 第一项为合并个数 其他项-1
              if (index == 0) {
                handleItemData.mergeNum = row.materials.length
                  ? row.materials.length
                  : 0;
              } else {
                handleItemData.mergeNum = -1;
              }
              // push为一维数组
              handleData.push(handleItemData);

              setTimeout(() => {
                this.loading = false;
              }, 200);
            });
          } else {
            this.loading = false;
            // 没有值时 也要展示
            handleData.push(handleItemData);
            handleItemData.mergeNum = 1;
          }
        });
      } else {
        this.loading = false;
      }

      // table的数据才是为处理好的数据
      this.sonData = handleData;
      // return console.log(this.sonData, "处理后的");

      // 点开的某项都插入到boxData的某项
      this.boxData.forEach((item, index) => {
        if (item.order_code == row.order_code) {
          item.sonData = [];

          this.sonData.forEach((items, indexs) => {
            if (item.order_code == items.order_code) {
              item.sonData.push(items);
            }
          });
        }
      });

      console.log(this.boxData, "处理后的");
    },

    // table表格  合并
    objectSpanMethod({ row, column, rowIndex, columnIndex }) {
      // 需要合并的
      if (columnIndex == 0 || columnIndex == 1) {
        if (row.mergeNum != -1) {
          return {
            rowspan: row.mergeNum,
            colspan: 1
          };
        } else {
          return {
            rowspan: 0,
            colspan: 0
          };
        }
      }
    }
  }
};
</script>

<style lang="scss">
.purchaseOrder {
  .el-table {
    margin-top: 10px;
  }
  // 暂时去掉hover
  .el-table tbody tr:hover > td {
    background: #fff;
  }
  .form-style {
  }
}
</style>
<style lang="scss" scoped></style>

 

参考合并https://blog.csdn.net/qq_38060231/article/details/108261350

posted on 2021-08-31 17:40  王多静  阅读(1307)  评论(0编辑  收藏  举报