diff --git a/docs/table/detail/options.md b/docs/table/detail/options.md index dc3baf41..97d996ad 100644 --- a/docs/table/detail/options.md +++ b/docs/table/detail/options.md @@ -123,6 +123,17 @@ - `height: 'full-30'` 设置相对可视屏幕的高度铺满。这是一个特定的语法格式:`full` 表示铺满;后面的数字表示当前 table 之外的元素占用的高度,如:表格头部到页面最顶部*加*表格底部距离页面最底部的“距离和” - `height: '#id-30'` 设置相对父元素的高度铺满,其中 `#id` 即父元素的 ID 选择器,其计算原理和上述 `full` 相同。 +**函数写法** 2.9.1+ + +当需要动态改变表格高度时建议使用,如下以等效 `full-xx` 的写法为例: + +``` +height: function(){ + var otherHeight = $('#search-content').outerHeight(); // 自定义其他区域的高度 + return $(window).height() - otherHeight; // 返回 number 类型 +} +``` + number
string - diff --git a/src/modules/table.js b/src/modules/table.js index 2b0d7ef4..23bc4812 100644 --- a/src/modules/table.js +++ b/src/modules/table.js @@ -360,6 +360,9 @@ layui.define(['lay', 'laytpl', 'laypage', 'form', 'util'], function(exports){ that.parentHeightGap = parentDiv.pop(); that.parentDiv = parentDiv.join("-"); options.height = $(that.parentDiv).height() - (parseFloat(that.parentHeightGap) || 0); + } else if (typeof options.height === "function"){ + that.customHeightFunc = options.height; + options.height = that.customHeightFunc(); } // 开始插入替代元素 @@ -1727,15 +1730,19 @@ layui.define(['lay', 'laytpl', 'laypage', 'form', 'util'], function(exports){ var options = that.config; var height = options.height; var bodyHeight; + var MIN_HEIGHT = 135; if(that.fullHeightGap){ height = _WIN.height() - that.fullHeightGap; - if(height < 135) height = 135; + if(height < MIN_HEIGHT) height = MIN_HEIGHT; // that.elem.css('height', height); } else if (that.parentDiv && that.parentHeightGap) { height = $(that.parentDiv).height() - that.parentHeightGap; - if (height < 135) height = 135; + if(height < MIN_HEIGHT) height = MIN_HEIGHT; // that.elem.css("height", height); + } else if (that.customHeightFunc) { + height = that.customHeightFunc(); + if(height < MIN_HEIGHT) height = MIN_HEIGHT; } // 如果多级表头,则填补表头高度