Merge branch 'main' of github.com:layui/layui

pull/1058/head
贤心 2022-06-28 21:01:35 +08:00
commit 25273fdcfd
3 changed files with 60 additions and 41 deletions

View File

@ -29,7 +29,8 @@
,"checkin": "106" ,"checkin": "106"
,"joinTime": "2016-10-14" ,"joinTime": "2016-10-14"
,"LAY_CHECKED": true ,"LAY_CHECKED": true
}, { ,"LAY_DISABLED": true
}, {
"id": "10003" "id": "10003"
,"username": "苏轼" ,"username": "苏轼"
,"email": "test3@email.com" ,"email": "test3@email.com"

View File

@ -989,13 +989,16 @@ a cite{font-style: normal; *cursor:pointer;}
.layui-table-page .layui-laypage input{width: 40px;} .layui-table-page .layui-laypage input{width: 40px;}
.layui-table-page .layui-laypage button{padding: 0 10px;} .layui-table-page .layui-laypage button{padding: 0 10px;}
.layui-table-page select{height: 18px;} .layui-table-page select{height: 18px;}
.layui-table-pagebar{float: right; line-height: 32px;} .layui-table-pagebar{float: right; line-height: 23px;}
.layui-table-pagebar .layui-btn-sm{margin-top: -1px;}
.layui-table-pagebar .layui-btn-xs{margin-top: 2px;}
.layui-table-view select[lay-ignore]{display: inline-block;} .layui-table-view select[lay-ignore]{display: inline-block;}
.layui-table-patch .layui-table-cell{padding: 0; width: 30px;} .layui-table-patch .layui-table-cell{padding: 0; width: 30px;}
.layui-table-edit{position: absolute; left: 0; top: 0; z-index: 900; min-width: 100%; min-height: 100%; padding: 5px 14px; border-radius: 0; box-shadow: 1px 1px 20px rgba(0,0,0,.15); background-color: #fff;} .layui-table-edit{position: absolute; left: 0; top: 0; z-index: 900; min-width: 100%; min-height: 100%; padding: 5px 14px; border-radius: 0; box-shadow: 1px 1px 20px rgba(0,0,0,.15); background-color: #fff;}
.layui-table-edit:focus{border-color: #5FB878!important;} .layui-table-edit:focus{border-color: #5FB878!important;}
input.layui-input.layui-table-edit{height: 100%;}
select.layui-table-edit{padding: 0 0 0 10px; border-color: #d2d2d2;} select.layui-table-edit{padding: 0 0 0 10px; border-color: #d2d2d2;}
.layui-table-view .layui-form-switch, .layui-table-view .layui-form-switch,
.layui-table-view .layui-form-checkbox, .layui-table-view .layui-form-checkbox,

View File

@ -197,7 +197,7 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
,'{{# }; }}' ,'{{# }; }}'
,'{{# if(right){ }}' ,'{{# if(right){ }}'
,'<div class="layui-table-fixed layui-table-fixed-r">' ,'<div class="layui-table-fixed layui-table-fixed-r layui-hide">'
,'<div class="layui-table-header">' ,'<div class="layui-table-header">'
,TPL_HEADER({fixed: 'right'}) ,TPL_HEADER({fixed: 'right'})
,'<div class="layui-table-mend"></div>' ,'<div class="layui-table-mend"></div>'
@ -217,13 +217,11 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
, '</table>' , '</table>'
,'</div>' ,'</div>'
,'{{# } }}' ,'{{# } }}'
,'{{# if(d.data.page || d.data.pagebar){ }}' ,'<div class="layui-table-column layui-table-page layui-hide">'
,'<div class="layui-table-column layui-table-page">'
,'<div class="layui-inline layui-table-pageview" id="layui-table-page{{=d.index}}"></div>' ,'<div class="layui-inline layui-table-pageview" id="layui-table-page{{=d.index}}"></div>'
,'</div>' ,'</div>'
,'{{# } }}'
,'<style>' ,'<style>'
,'{{# layui.each(d.data.cols, function(i1, item1){' ,'{{# layui.each(d.data.cols, function(i1, item1){'
,'layui.each(item1, function(i2, item2){ }}' ,'layui.each(item1, function(i2, item2){ }}'
@ -380,7 +378,12 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
if(options.cols.length > 1){ if(options.cols.length > 1){
// 补全高度 // 补全高度
var th = that.layFixed.find(ELEM_HEADER).find('th'); var th = that.layFixed.find(ELEM_HEADER).find('th');
th.height(that.layHeader.height() - 1 - parseFloat(th.css('padding-top')) - parseFloat(th.css('padding-bottom'))); // 固定列表头同步跟本体th一致高度
var headerMain = that.layHeader.first();
layui.each(th, function (thIndex, thElem) {
thElem = $(thElem);
thElem.height(headerMain.find('th[data-key="' + thElem.attr('data-key') + '"]').height() + 'px');
})
} }
that.pullData(that.page); //请求数据 that.pullData(that.page); //请求数据
@ -395,7 +398,7 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
checkbox: 50 checkbox: 50
,radio: 50 ,radio: 50
,space: 15 ,space: 15
,numbers: 40 ,numbers: 60
}; };
//让 type 参数兼容旧版本 //让 type 参数兼容旧版本
@ -867,6 +870,10 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
//渲染视图 //渲染视图
,render = function(){ //后续性能提升的重点 ,render = function(){ //后续性能提升的重点
//同步表头父列的相关值
options.HAS_SET_COLS_PATCH || that.setColsPatch();
options.HAS_SET_COLS_PATCH = true;
var thisCheckedRowIndex; var thisCheckedRowIndex;
if(!sort && that.sortKey){ if(!sort && that.sortKey){
return that.sort(that.sortKey.field, that.sortKey.sort, true); return that.sort(that.sortKey.field, that.sortKey.sort, true);
@ -998,7 +1005,9 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
that.renderForm(); that.renderForm();
typeof thisCheckedRowIndex === 'number' && that.setThisRowChecked(thisCheckedRowIndex); typeof thisCheckedRowIndex === 'number' && that.setThisRowChecked(thisCheckedRowIndex);
that.syncCheckAll(); that.syncCheckAll();
// 因为page参数有可能发生变化 先重新铺满
that.fullSize();
//滚动条补丁 //滚动条补丁
that.haveInit ? that.scrollPatch() : setTimeout(function(){ that.haveInit ? that.scrollPatch() : setTimeout(function(){
that.scrollPatch(); that.scrollPatch();
@ -1006,14 +1015,10 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
that.haveInit = true; that.haveInit = true;
layer.close(that.tipsIndex); layer.close(that.tipsIndex);
//同步表头父列的相关值
options.HAS_SET_COLS_PATCH || that.setColsPatch();
options.HAS_SET_COLS_PATCH = true;
}; };
table.cache[that.key] = data; //记录数据 table.cache[that.key] = data; //记录数据
//显示隐藏分页栏 //显示隐藏分页栏
//that.layPage[(count == 0 || (data.length === 0 && curr == 1)) ? 'addClass' : 'removeClass'](HIDE); //that.layPage[(count == 0 || (data.length === 0 && curr == 1)) ? 'addClass' : 'removeClass'](HIDE);
@ -1021,9 +1026,10 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
that.layTotal[data.length == 0 ? 'addClass' : 'removeClass'](HIDE_V); that.layTotal[data.length == 0 ? 'addClass' : 'removeClass'](HIDE_V);
//显示隐藏分页栏 //显示隐藏分页栏
that.layPage[(options.page || options.pagebar) ? 'removeClass' : 'addClass'](HIDE);
that.layPage.find(ELEM_PAGE_VIEW)[ that.layPage.find(ELEM_PAGE_VIEW)[
(count == 0 || (data.length === 0 && curr == 1)) (!options.page || count == 0 || (data.length === 0 && curr == 1))
? 'addClass' ? 'addClass'
: 'removeClass' : 'removeClass'
](HIDE_V); ](HIDE_V);
@ -1032,7 +1038,7 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
that.renderForm(); that.renderForm();
return that.errorView(options.text.none); return that.errorView(options.text.none);
} else { } else {
that.layFixed.removeClass(HIDE); that.layFixLeft.removeClass(HIDE);
} }
//如果执行初始排序 //如果执行初始排序
@ -1079,7 +1085,7 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
,totalNums = {}; ,totalNums = {};
if(!options.totalRow) return; if(!options.totalRow) return;
layui.each(data, function(i1, item1){ layui.each(data, function(i1, item1){
//若数据项为空数组,则不往下执行(因为删除数据时,会将原有数据设置为 [] //若数据项为空数组,则不往下执行(因为删除数据时,会将原有数据设置为 []
if(layui.type(item1) === 'array' && item1.length === 0) return; if(layui.type(item1) === 'array' && item1.length === 0) return;
@ -1350,18 +1356,18 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
if(options.toolbar){ if(options.toolbar){
bodyHeight -= (that.layTool.outerHeight() || 50); bodyHeight -= (that.layTool.outerHeight() || 50);
} }
//减去统计的高度 //减去统计的高度
if(options.totalRow){ if(options.totalRow){
bodyHeight -= (that.layTotal.outerHeight() || 40); bodyHeight -= (that.layTotal.outerHeight() || 40);
} }
//减去分页栏的高度 //减去分页栏的高度
if(options.page){ if(options.page || options.pagebar){
bodyHeight -= (that.layPage.outerHeight() || 41); bodyHeight -= (that.layPage.outerHeight() || 43);
} }
that.layMain.css('height', bodyHeight - 2); that.layMain.outerHeight(bodyHeight);
}; };
//获取滚动条宽度 //获取滚动条宽度
@ -1666,7 +1672,7 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
tr: tr //行元素 tr: tr //行元素
,data: table.clearCacheKey(data) //当前行数据 ,data: table.clearCacheKey(data) //当前行数据
,del: function(){ //删除行数据 ,del: function(){ //删除行数据
table.cache[that.key][index] = []; table.cache[that.key][index] = [];
tr.remove(); tr.remove();
that.scrollPatch(); that.scrollPatch();
} }
@ -1674,11 +1680,11 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
fields = fields || {}; fields = fields || {};
layui.each(fields, function(key, value){ layui.each(fields, function(key, value){
var td = tr.children('td[data-field="'+ key +'"]') var td = tr.children('td[data-field="'+ key +'"]')
,cell = td.children(ELEM_CELL); //获取当前修改的列 ,cell = td.children(ELEM_CELL); //获取当前修改的列
//更新缓存中的数据 //更新缓存中的数据
if(key in data) data[key] = value; if(key in data) data[key] = value;
that.eachCols(function(i, item3){ that.eachCols(function(i, item3){
//更新相应列视图 //更新相应列视图
if(item3.field == key){ if(item3.field == key){
@ -1691,7 +1697,7 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
item3.templet && that.renderForm(); item3.templet && that.renderForm();
} else if(item3.templet || item3.toolbar){ //更新所有其他列的模板 } else if(item3.templet || item3.toolbar){ //更新所有其他列的模板
var thisTd = tr.children('td[data-field="'+ (item3.field || i) +'"]') var thisTd = tr.children('td[data-field="'+ (item3.field || i) +'"]')
,content = data[item3.field]; ,content = data[item3.field];
thisTd.children(ELEM_CELL).html(parseTempData.call(that, { thisTd.children(ELEM_CELL).html(parseTempData.call(that, {
item3: item3 item3: item3
,content: content ,content: content
@ -1702,6 +1708,8 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
} }
}); });
}); });
that.renderForm();
} }
}, sets); }, sets);
}; };
@ -1798,7 +1806,6 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
,data = table.cache[that.key][index]; ,data = table.cache[that.key][index];
data[field] = value; //更新缓存中的值 data[field] = value; //更新缓存中的值
layui.event.call(this, MOD_NAME, 'edit('+ filter +')', commonMember.call(this, { layui.event.call(this, MOD_NAME, 'edit('+ filter +')', commonMember.call(this, {
value: value value: value
,field: field ,field: field
@ -2060,13 +2067,21 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
// 找到它的子列所在cols的下标 // 找到它的子列所在cols的下标
var i2 = i1 + (parseInt(item2.rowspan) || 1); var i2 = i1 + (parseInt(item2.rowspan) || 1);
layui.each(cols[i2], function (i22, item22) { layui.each(cols[i2], function (i22, item22) {
//如果子列已经被标注为{PARENT_COL_INDEX},或者子列累计 colspan 数等于父列定义的 colspan则跳出当前子列循环 if (item22.parentKey) { // 如果字段信息中包含了parentKey和key信息
if (item22.PARENT_COL_INDEX || (childIndex >= 1 && childIndex == (item2.colspan || 1))) return; if (item22.parentKey === item2.key) {
item22.PARENT_COL_INDEX = index; item22.PARENT_COL_INDEX = index;
item2.CHILD_COLS.push(item22);
item2.CHILD_COLS.push(item22); eachChildCols(index, cols, i2, item22);
childIndex = childIndex + (item22.hide ? 0 : parseInt(item22.colspan > 1 ? item22.colspan : 1)); }
eachChildCols(index, cols, i2, item22); } else {
// 没有key信息以colspan数量所谓判断标准
//如果子列已经被标注为{PARENT_COL_INDEX},或者子列累计 colspan 数等于父列定义的 colspan则跳出当前子列循环
if (item22.PARENT_COL_INDEX || (childIndex >= 1 && childIndex == (item2.colspan || 1))) return;
item22.PARENT_COL_INDEX = index;
item2.CHILD_COLS.push(item22);
childIndex = childIndex + (item22.hide ? 0 : parseInt(item22.colspan > 1 ? item22.colspan : 1));
eachChildCols(index, cols, i2, item22);
}
}); });
} }
}; };
@ -2102,9 +2117,9 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
// 表格选中状态 // 表格选中状态
table.checkStatus = function(id){ table.checkStatus = function(id){
var nums = 0 var nums = 0
,invalidNum = 0 ,invalidNum = 0
,arr = [] ,arr = []
,data = table.cache[id] || []; ,data = table.cache[id] || [];
//计算全选个数 //计算全选个数
layui.each(data, function(i, item){ layui.each(data, function(i, item){