tableMerge.js 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. /**
  2. *
  3. * @name: 子表格扩展
  4. * @author: yelog
  5. * @version: v1.4.4
  6. */
  7. layui.define(['table'], function (exports) {
  8. var $ = layui.jquery;
  9. // 封装方法
  10. var mod = {
  11. /**
  12. * 渲染入口
  13. * @param myTable
  14. */
  15. render: function (myTable) {
  16. var tableBox = $(myTable.elem).next().children('.layui-table-box'),
  17. $main = $(tableBox.children('.layui-table-body').children('table').children('tbody').children('tr').toArray().reverse()),
  18. $fixLeft = $(tableBox.children('.layui-table-fixed-l').children('.layui-table-body').children('table').children('tbody').children('tr').toArray().reverse()),
  19. $fixRight = $(tableBox.children('.layui-table-fixed-r').children('.layui-table-body').children('table').children('tbody').children('tr').toArray().reverse()),
  20. mergeRecord = {};
  21. layui.each(myTable.cols, function (i1, item1) {
  22. layui.each(item1, function (i2, item2) {
  23. if (item2.merge && item2.field) {
  24. var mergeField = [item2.field];
  25. if (item2.merge !== true) {
  26. if (typeof item2.merge === 'string') {
  27. mergeField = [item2.merge]
  28. } else {
  29. mergeField = item2.merge
  30. }
  31. }
  32. mergeRecord[myTable.index + '-' + i1 + '-' + i2] = {mergeField: mergeField, rowspan: 1}
  33. }
  34. })
  35. })
  36. $main.each(function (i) {
  37. for (var item in mergeRecord) {
  38. if (i === $main.length - 1 || isMaster(i, item)) {
  39. var tdHeight = $(this).children('[data-key="' + item + '"]').outerHeight(), patchHeight = 0; // 获取td高度
  40. if ($main.eq(i).data('index') === 0) {
  41. patchHeight = 1
  42. }
  43. $(this).children('[data-key="' + item + '"]').attr('rowspan', mergeRecord[item].rowspan).css({
  44. 'position': 'static',
  45. 'height': tdHeight * mergeRecord[item].rowspan + patchHeight
  46. }).children().css({
  47. height: 'auto',
  48. 'white-space': 'normal',
  49. 'max-height': tdHeight * mergeRecord[item].rowspan + patchHeight - 10
  50. });
  51. $fixLeft.eq(i).children('[data-key="' + item + '"]').attr('rowspan', mergeRecord[item].rowspan).css({
  52. 'position': 'static',
  53. 'height': tdHeight * mergeRecord[item].rowspan + patchHeight
  54. }).children().css({
  55. height: 'auto',
  56. 'white-space': 'normal',
  57. 'max-height': tdHeight * mergeRecord[item].rowspan + patchHeight - 10
  58. });
  59. $fixRight.eq(i).children('[data-key="' + item + '"]').attr('rowspan', mergeRecord[item].rowspan).css({
  60. 'position': 'static',
  61. 'height': tdHeight * mergeRecord[item].rowspan + patchHeight
  62. }).children().css({
  63. height: 'auto',
  64. 'white-space': 'normal',
  65. 'max-height': tdHeight * mergeRecord[item].rowspan + patchHeight - 10
  66. });
  67. mergeRecord[item].rowspan = 1;
  68. } else {
  69. $(this).children('[data-key="' + item + '"]').remove();
  70. $fixLeft.eq(i).children('[data-key="' + item + '"]').remove();
  71. $fixRight.eq(i).children('[data-key="' + item + '"]').remove();
  72. mergeRecord[item].rowspan += 1;
  73. }
  74. }
  75. })
  76. function isMaster(index, item) {
  77. var mergeField = mergeRecord[item].mergeField;
  78. var dataLength = layui.table.cache[myTable.id].length;
  79. for (var i = 0; i < mergeField.length; i++) {
  80. if (layui.table.cache[myTable.id][dataLength - 2 - index][mergeField[i]]
  81. !== layui.table.cache[myTable.id][dataLength - 1 - index][mergeField[i]]) {
  82. return true;
  83. }
  84. }
  85. return false;
  86. }
  87. }
  88. };
  89. // 输出
  90. exports('tableMerge', mod);
  91. });