经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » HTML5 » 查看文章
Vue+elementui 实现复杂表头和动态增加列的二维表格
来源:cnblogs  作者:了、凡  时间:2019/9/23 8:50:53  对本文有异议

先上完成的效果图:列是根据查询结果增加的

 数据格式:

 表头的数据取出:

  1. data.data.forEach(element => {
  2. this.thead.push({
  3. 品名: element.品名,
  4. 面取数: element.面取数,
  5. LOTNO: element.LOT
  6. });

 element table中:

  1. <el-table-column
  2. v-for="(item,index) in thead"
  3. :prop="item.LOTNO"
  4. :key="index"
  5. align="center"
  6. width="180"
  7. >
  8. <template slot="header">
  9. <tr>
  10. <td>{{item.品名}}</td>
  11. </tr>
  12. <tr>
  13. <td>{{item.面取数}}</td>
  14. </tr>
  15. <tr>
  16. <td @click="querylot(item.LOTNO)">
  17. <el-link>{{item.LOTNO}}</el-link>
  18. </td>
  19. </tr>
  20. </template>
  21. </el-table-column>

  表格内数据整理:

  1. for (let index1 = 3;index1 < Object.keys(结果_data[0]).length;index1++) {
  2. let newmap = new Map();
  3. let datakey = Object.keys(结果_data[0])[index1];
  4. newmap.set("mode", datakey); //取出每个数组对象的键值
  5. for (let index2 = 0; index2 < 结果_data_length; index2++) {
  6. let datavalue = 结果_data[index2][Object.keys(结果_data[0])[index1]];
  7. if (datakey == "投入日期") {
  8. datavalue = datavalue.slice(0, 10);
  9. }
  10. newmap.set(
  11. 结果_data[index2][Object.keys(结果_data[index2])[0]],datavalue);//获得这个键对应的所有的值
  12. }

  左侧表头合并:需要注意的是,当有固定列的时候需要设置表格的max-height属性,不然会出现列空白

    <el-table :data="tableData" span-method="objectSpanMethod">
  1. objectSpanMethod({ row, column, rowIndex, columnIndex }) {
  2. if (columnIndex === 0) {
  3. if (rowIndex % this.tableData.length === 0) {
  4. return {
  5. rowspan: this.tableData.length,
  6. colspan: 1
  7. };
  8. } else {
  9. return {
  10. rowspan: 0,
  11. colspan: 0
  12. };
  13. }
  14. }
  15. }

  表格导出:

  1. import FileSaver from "file-saver";
  2. import XLSX from "xlsx";
  3. output() {
  4. alert(1);
  5. let wb = XLSX.utils.table_to_book(document.querySelector("#mytable")); //mytable为表格的id名
  6. let wbout = XLSX.write(wb, {
  7. bookType: "xlsx",
  8. bookSST: true,
  9. type: "array"
  10. });
  11. try {
  12. FileSaver.saveAs(
  13. new Blob([wbout], { type: "application/octet-stream" }),
  14. "sheet.xlsx"
  15. );
  16. } catch (e) {
  17. if (typeof console !== "undefined") console.log(e, wbout);
  18. }
  19. return wbout;
  20. }

  

 

原文链接:http://www.cnblogs.com/ly612322/p/11551915.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号