Commit 492402f4 by fengshuonan

修复treetable收缩不能收缩子所有级的bug

parent 1afcd90a
(function($) { /**
"use strict"; * 查找当前这个节点的所有节点(包含子节点),并进行折叠或者展开操作
*
* @param item 被点击条目的子一级条目
* @param target 整个bootstrap tree table实例
* @param globalCollapsedFlag 如果为true,则表示当前操作是收缩(折叠),如果是false,表示当前操作是展开
* @param options 存放了一些常量,例如展开和收缩的class
*/
function extracted($, item, target, globalCollapsedFlag, options) {
var itemCodeName = $(item).find("td[name='code']").text();
var subItems = target.find("tbody").find(".tg-" + itemCodeName);//下一级,改为下所有级别
$.fn.bootstrapTreeTable = function(options, param) { if (subItems.size() > 0) {
var allData = null;//用于存放格式化后的数据 $.each(subItems, function (nIndex, nItem) {
// 如果是调用方法 extracted($, nItem, target, globalCollapsedFlag, options);
if (typeof options == 'string') { });
return $.fn.bootstrapTreeTable.methods[options](this, param); }
} $.each(subItems, function (pIndex, pItem) {
// 如果是初始化组件
options = $.extend({}, $.fn.bootstrapTreeTable.defaults, options || {}); //如果是展开,判断当前箭头是开启还是关闭
// 是否有radio或checkbox if (!globalCollapsedFlag) {
var hasSelectItem = false; var hasExpander = $(item).find("td[name='name']").find(".treetable-expander")
var target = $(this); .hasClass(options.expanderExpandedClass);
// 在外层包装一下div,样式用的bootstrap-table的 if (hasExpander) {
var _main_div = $("<div class='bootstrap-tree-table fixed-table-container'></div>"); $(pItem).css("display", "table");
target.before(_main_div); } else {
_main_div.append(target); $(pItem).css("display", "none");
target.addClass("table table-hover treetable-table table-bordered"); }
if (options.striped) { } else {
target.addClass('table-striped'); $(pItem).css("display", "none");
} }
// 工具条在外层包装一下div,样式用的bootstrap-table的 });
if(options.toolbar){ }
var _tool_div = $("<div class='fixed-table-toolbar'></div>");
var _tool_left_div = $("<div class='bs-bars pull-left'></div>"); (function ($) {
_tool_left_div.append($(options.toolbar)); "use strict";
_tool_div.append(_tool_left_div);
_main_div.before(_tool_div); $.fn.bootstrapTreeTable = function (options, param) {
} var allData = null;//用于存放格式化后的数据
// 格式化数据,优化性能 // 如果是调用方法
target.formatData=function(data){ if (typeof options == 'string') {
var _root = options.rootCodeValue?options.rootCodeValue:null return $.fn.bootstrapTreeTable.methods[options](this, param);
$.each(data, function(index, item) { }
// 添加一个默认属性,用来判断当前节点有没有被显示 // 如果是初始化组件
item.isShow = false; options = $.extend({}, $.fn.bootstrapTreeTable.defaults, options || {});
// 这里兼容几种常见Root节点写法 // 是否有radio或checkbox
// 默认的几种判断 var hasSelectItem = false;
var _defaultRootFlag = item[options.parentCode] == '0' var target = $(this);
|| item[options.parentCode] == 0 // 在外层包装一下div,样式用的bootstrap-table的
|| item[options.parentCode] == null var _main_div = $("<div class='bootstrap-tree-table fixed-table-container'></div>");
|| item[options.parentCode] == ''; target.before(_main_div);
if (!item[options.parentCode] || (_root?(item[options.parentCode] == options.rootCodeValue):_defaultRootFlag)){ _main_div.append(target);
if(!allData["_root_"]){allData["_root_"]=[];} target.addClass("table table-hover treetable-table table-bordered");
allData["_root_"].push(item); if (options.striped) {
}else{ target.addClass('table-striped');
if(!allData["_n_"+item[options.parentCode]]){allData["_n_"+item[options.parentCode]]=[];} }
allData["_n_"+item[options.parentCode]].push(item); // 工具条在外层包装一下div,样式用的bootstrap-table的
} if (options.toolbar) {
}); var _tool_div = $("<div class='fixed-table-toolbar'></div>");
} var _tool_left_div = $("<div class='bs-bars pull-left'></div>");
// 得到根节点 _tool_left_div.append($(options.toolbar));
target.getRootNodes = function() { _tool_div.append(_tool_left_div);
return allData["_root_"]; _main_div.before(_tool_div);
}; }
// 递归获取子节点并且设置子节点 // 格式化数据,优化性能
target.handleNode = function(parentNode, lv, tbody) { target.formatData = function (data) {
var _ls = allData["_n_"+parentNode[options.code]]; var _root = options.rootCodeValue ? options.rootCodeValue : null
var tr = target.renderRow(parentNode,_ls?true:false,lv); $.each(data, function (index, item) {
tbody.append(tr); // 添加一个默认属性,用来判断当前节点有没有被显示
if(_ls){ item.isShow = false;
$.each(_ls, function(i, item) { // 这里兼容几种常见Root节点写法
target.handleNode(item, (lv + 1), tbody) // 默认的几种判断
}); var _defaultRootFlag = item[options.parentCode] == '0'
} || item[options.parentCode] == 0
}; || item[options.parentCode] == null
// 绘制行 || item[options.parentCode] == '';
target.renderRow = function(item,isP,lv){ if (!item[options.parentCode] || (_root ? (item[options.parentCode] == options.rootCodeValue) : _defaultRootFlag)) {
// 标记已显示 if (!allData["_root_"]) {
item.isShow = true; allData["_root_"] = [];
var tr = $('<tr class="tg-'+item[options.parentCode]+'"></tr>'); }
var _icon = options.expanderCollapsedClass; allData["_root_"].push(item);
if(options.expandAll){ } else {
tr.css("display","table"); if (!allData["_n_" + item[options.parentCode]]) {
_icon = options.expanderExpandedClass; allData["_n_" + item[options.parentCode]] = [];
}else if(options.expandFirst&&lv<=2){ }
tr.css("display","table"); allData["_n_" + item[options.parentCode]].push(item);
_icon=(lv==1)?options.expanderExpandedClass:options.expanderCollapsedClass; }
}else{ });
tr.css("display","none"); }
_icon = options.expanderCollapsedClass; // 得到根节点
} target.getRootNodes = function () {
$.each(options.columns, function(index, column) { return allData["_root_"];
// 判断有没有选择列 };
if(index==0&&column.field=='selectItem'){ // 递归获取子节点并且设置子节点
hasSelectItem = true; target.handleNode = function (parentNode, lv, tbody) {
var td = $('<td style="text-align:center;width:36px"></td>'); var _ls = allData["_n_" + parentNode[options.code]];
if(column.radio){ var tr = target.renderRow(parentNode, _ls ? true : false, lv);
var _ipt = $('<input name="select_item" type="radio" value="'+item[options.id]+'"></input>'); tbody.append(tr);
td.append(_ipt); if (_ls) {
} $.each(_ls, function (i, item) {
if(column.checkbox){ target.handleNode(item, (lv + 1), tbody)
var _ipt = $('<input name="select_item" type="checkbox" value="'+item[options.id]+'"></input>'); });
td.append(_ipt); }
} };
tr.append(td); // 绘制行
}else{ target.renderRow = function (item, isP, lv) {
var td = $('<td title="'+item[column.field]+'" name="'+column.field+'" style="'+((column.width)?('width:'+column.width):'')+'"></td>'); // 标记已显示
// 增加formatter渲染 item.isShow = true;
var tr = $('<tr class="tg-' + item[options.parentCode] + '"></tr>');
var _icon = options.expanderCollapsedClass;
if (options.expandAll) {
tr.css("display", "table");
_icon = options.expanderExpandedClass;
} else if (options.expandFirst && lv <= 2) {
tr.css("display", "table");
_icon = (lv == 1) ? options.expanderExpandedClass : options.expanderCollapsedClass;
} else {
tr.css("display", "none");
_icon = options.expanderCollapsedClass;
}
$.each(options.columns, function (index, column) {
// 判断有没有选择列
if (index == 0 && column.field == 'selectItem') {
hasSelectItem = true;
var td = $('<td style="text-align:center;width:36px"></td>');
if (column.radio) {
var _ipt = $('<input name="select_item" type="radio" value="' + item[options.id] + '"></input>');
td.append(_ipt);
}
if (column.checkbox) {
var _ipt = $('<input name="select_item" type="checkbox" value="' + item[options.id] + '"></input>');
td.append(_ipt);
}
tr.append(td);
} else {
var td = $('<td title="' + item[column.field] + '" name="' + column.field + '" style="' + ((column.width) ? ('width:' + column.width) : '') + '"></td>');
// 增加formatter渲染
if (column.formatter) { if (column.formatter) {
td.html(column.formatter.call(this, item[column.field], item, index)); td.html(column.formatter.call(this, item[column.field], item, index));
} else { } else {
td.text(item[column.field]); td.text(item[column.field]);
} }
if(options.expandColumn==index){ if (options.expandColumn == index) {
if(!isP){ if (!isP) {
td.prepend('<span class="treetable-expander"></span>') td.prepend('<span class="treetable-expander"></span>')
}else{ } else {
td.prepend('<span class="treetable-expander '+_icon+'"></span>') td.prepend('<span class="treetable-expander ' + _icon + '"></span>')
} }
for (var int = 0; int < (lv-1); int++) { for (var int = 0; int < (lv - 1); int++) {
td.prepend('<span class="treetable-indent"></span>') td.prepend('<span class="treetable-indent"></span>')
} }
} }
tr.append(td); tr.append(td);
} }
}); });
return tr; return tr;
} }
// 加载数据 // 加载数据
target.load = function(parms){ target.load = function (parms) {
// 加载数据前先清空 // 加载数据前先清空
allData = {}; allData = {};
// 加载数据前先清空 // 加载数据前先清空
target.html(""); target.html("");
// 构造表头 // 构造表头
var thr = $('<tr></tr>'); var thr = $('<tr></tr>');
$.each(options.columns, function(i, item) { $.each(options.columns, function (i, item) {
var th = null; var th = null;
// 判断有没有选择列 // 判断有没有选择列
if(i==0&&item.field=='selectItem'){ if (i == 0 && item.field == 'selectItem') {
hasSelectItem = true; hasSelectItem = true;
th = $('<th style="width:36px"></th>'); th = $('<th style="width:36px"></th>');
}else{ } else {
th = $('<th style="'+((item.width)?('width:'+item.width):'')+'"></th>'); th = $('<th style="' + ((item.width) ? ('width:' + item.width) : '') + '"></th>');
} }
th.text(item.title); th.text(item.title);
thr.append(th); thr.append(th);
}); });
var thead = $('<thead class="treetable-thead"></thead>'); var thead = $('<thead class="treetable-thead"></thead>');
thead.append(thr); thead.append(thr);
target.append(thead); target.append(thead);
// 构造表体 // 构造表体
var tbody = $('<tbody class="treetable-tbody"></tbody>'); var tbody = $('<tbody class="treetable-tbody"></tbody>');
target.append(tbody); target.append(tbody);
// 添加加载loading // 添加加载loading
var _loading = '<tr><td colspan="'+options.columns.length+'"><div style="display: block;text-align: center;">正在努力地加载数据中,请稍候……</div></td></tr>' var _loading = '<tr><td colspan="' + options.columns.length + '"><div style="display: block;text-align: center;">正在努力地加载数据中,请稍候……</div></td></tr>'
tbody.html(_loading); tbody.html(_loading);
// 默认高度 // 默认高度
if(options.height){ if (options.height) {
tbody.css("height",options.height); tbody.css("height", options.height);
} }
$.ajax({ $.ajax({
type : options.type, type: options.type,
url : options.url, url: options.url,
data : parms?parms:options.ajaxParams, data: parms ? parms : options.ajaxParams,
dataType : "JSON", dataType: "JSON",
success : function(data, textStatus, jqXHR) { success: function (data, textStatus, jqXHR) {
// 加载完数据先清空 // 加载完数据先清空
tbody.html(""); tbody.html("");
if(!data||data.length<=0){ if (!data || data.length <= 0) {
var _empty = '<tr><td colspan="'+options.columns.length+'"><div style="display: block;text-align: center;">没有找到匹配的记录</div></td></tr>' var _empty = '<tr><td colspan="' + options.columns.length + '"><div style="display: block;text-align: center;">没有找到匹配的记录</div></td></tr>'
tbody.html(_empty); tbody.html(_empty);
return; return;
} }
// 格式化数据 // 格式化数据
target.formatData(data); target.formatData(data);
// 开始绘制 // 开始绘制
var rootNode = target.getRootNodes(); var rootNode = target.getRootNodes();
if(rootNode){ if (rootNode) {
$.each(rootNode, function(i, item) { $.each(rootNode, function (i, item) {
target.handleNode(item, 1, tbody); target.handleNode(item, 1, tbody);
}); });
} }
// 下边的操作主要是为了查询时让一些没有根节点的节点显示 // 下边的操作主要是为了查询时让一些没有根节点的节点显示
$.each(data, function(i, item) { $.each(data, function (i, item) {
if(!item.isShow){ if (!item.isShow) {
var tr = target.renderRow(item,false,1); var tr = target.renderRow(item, false, 1);
tbody.append(tr); tbody.append(tr);
} }
}); });
target.append(tbody); target.append(tbody);
//动态设置表头宽度 //动态设置表头宽度
thead.css("width", tbody.children(":first").css("width")); thead.css("width", tbody.children(":first").css("width"));
// 行点击选中事件 // 行点击选中事件
target.find("tbody").find("tr").click(function(){ target.find("tbody").find("tr").click(function () {
if(hasSelectItem){ if (hasSelectItem) {
var _ipt = $(this).find("input[name='select_item']"); var _ipt = $(this).find("input[name='select_item']");
if(_ipt.attr("type")=="radio"){ if (_ipt.attr("type") == "radio") {
_ipt.prop('checked',true); _ipt.prop('checked', true);
target.find("tbody").find("tr").removeClass("treetable-selected"); target.find("tbody").find("tr").removeClass("treetable-selected");
$(this).addClass("treetable-selected"); $(this).addClass("treetable-selected");
}else{ } else {
if(_ipt.prop('checked')){ if (_ipt.prop('checked')) {
_ipt.prop('checked',false); _ipt.prop('checked', false);
$(this).removeClass("treetable-selected"); $(this).removeClass("treetable-selected");
}else{ } else {
_ipt.prop('checked',true); _ipt.prop('checked', true);
$(this).addClass("treetable-selected"); $(this).addClass("treetable-selected");
} }
} }
} }
}); });
// 小图标点击事件--展开缩起 // 小图标点击事件--展开缩起
target.find("tbody").find("tr").find(".treetable-expander").click(function(){ target.find("tbody").find("tr").find(".treetable-expander").click(function () {
var tr = $(this).parent().parent(); var tr = $(this).parent().parent();
var _code = tr.find("input[name='select_item']").val(); var _code = tr.find("input[name='select_item']").val();
if(options.id==options.code){ if (options.id == options.code) {
_code = tr.find("input[name='select_item']").val(); _code = tr.find("input[name='select_item']").val();
}else{ } else {
_code = tr.find("td[name='"+options.code+"']").text(); _code = tr.find("td[name='" + options.code + "']").text();
} }
var _ls = target.find("tbody").find(".tg-"+_code);//下一级,改为下所有级别 var _ls = target.find("tbody").find(".tg-" + _code);//下一级,改为下所有级别
if(_ls&&_ls.length>0){ if (_ls && _ls.length > 0) {
var _flag = $(this).hasClass(options.expanderExpandedClass); var _flag = $(this).hasClass(options.expanderExpandedClass);
$.each(_ls, function(index, item) { $.each(_ls, function (index, item) {
//查找当前这个节点的所有节点(包含子节点),如果是折叠都显示为不显示,如果是展开,则根据当前节点的状态
var pcode = $(item).find("td[name='code']").text();
var pcodes = target.find("tbody").find(".tg-"+pcode);//下一级,改为下所有级别
$.each(pcodes, function(pIndex, pItem) {
//如果是展开,判断当前箭头是开启还是关闭 //查找当前这个节点的所有节点(包含子节点),如果是折叠都显示为不显示,如果是展开,则根据当前节点的状态
if(!_flag){ extracted($, item, target, _flag, options);
debugger;
var hasExpander = $(item).find("td[name='name']").find(".treetable-expander")
.hasClass(options.expanderExpandedClass);
if (hasExpander) {
$(pItem).css("display","table");
}else{
$(pItem).css("display","none");
}
}else{
$(pItem).css("display","none");
}
});
$(item).css("display",_flag?"none":"table"); $(item).css("display", _flag ? "none" : "table");
}); });
if(_flag){ if (_flag) {
$(this).removeClass(options.expanderExpandedClass) $(this).removeClass(options.expanderExpandedClass)
$(this).addClass(options.expanderCollapsedClass) $(this).addClass(options.expanderCollapsedClass)
}else{ } else {
$(this).removeClass(options.expanderCollapsedClass) $(this).removeClass(options.expanderCollapsedClass)
$(this).addClass(options.expanderExpandedClass) $(this).addClass(options.expanderExpandedClass)
} }
} }
}); });
}, },
error:function(xhr,textStatus){ error: function (xhr, textStatus) {
var _errorMsg = '<tr><td colspan="'+options.columns.length+'"><div style="display: block;text-align: center;">'+xhr.responseText+'</div></td></tr>' var _errorMsg = '<tr><td colspan="' + options.columns.length + '"><div style="display: block;text-align: center;">' + xhr.responseText + '</div></td></tr>'
tbody.html(_errorMsg); tbody.html(_errorMsg);
debugger; debugger;
}, },
}); });
} }
if (options.url) { if (options.url) {
target.load(); target.load();
} else { } else {
// 也可以通过defaults里面的data属性通过传递一个数据集合进来对组件进行初始化....有兴趣可以自己实现,思路和上述类似 // 也可以通过defaults里面的data属性通过传递一个数据集合进来对组件进行初始化....有兴趣可以自己实现,思路和上述类似
} }
return target; return target;
}; };
// 组件方法封装........ // 组件方法封装........
$.fn.bootstrapTreeTable.methods = { $.fn.bootstrapTreeTable.methods = {
// 返回选中记录的id(返回的id由配置中的id属性指定) // 返回选中记录的id(返回的id由配置中的id属性指定)
// 为了兼容bootstrap-table的写法,统一返回数组,这里只返回了指定的id // 为了兼容bootstrap-table的写法,统一返回数组,这里只返回了指定的id
getSelections : function(target, data) { getSelections: function (target, data) {
// 所有被选中的记录input // 所有被选中的记录input
var _ipt = target.find("tbody").find("tr").find("input[name='select_item']:checked"); var _ipt = target.find("tbody").find("tr").find("input[name='select_item']:checked");
var chk_value =[]; var chk_value = [];
// 如果是radio // 如果是radio
if(_ipt.attr("type")=="radio"){ if (_ipt.attr("type") == "radio") {
var _data = {id:_ipt.val()}; var _data = {id: _ipt.val()};
var _tds = _ipt.parent().parent().find("td"); var _tds = _ipt.parent().parent().find("td");
_tds.each(function(_i,_item){ _tds.each(function (_i, _item) {
if(_i!=0){ if (_i != 0) {
_data[$(_item).attr("name")]=$(_item).text(); _data[$(_item).attr("name")] = $(_item).text();
} }
}); });
chk_value.push(_data); chk_value.push(_data);
}else{ } else {
_ipt.each(function(_i,_item){ _ipt.each(function (_i, _item) {
var _data = {id:$(_item).val()}; var _data = {id: $(_item).val()};
var _tds = $(_item).parent().parent().find("td"); var _tds = $(_item).parent().parent().find("td");
_tds.each(function(_ii,_iitem){ _tds.each(function (_ii, _iitem) {
if(_ii!=0){ if (_ii != 0) {
_data[$(_iitem).attr("name")]=$(_iitem).text(); _data[$(_iitem).attr("name")] = $(_iitem).text();
} }
}); });
chk_value.push(_data); chk_value.push(_data);
}); });
} }
return chk_value; return chk_value;
}, },
// 刷新记录 // 刷新记录
refresh : function(target, parms) { refresh: function (target, parms) {
if(parms){ if (parms) {
target.load(parms); target.load(parms);
}else{ } else {
target.load(); target.load();
} }
}, },
// 组件的其他方法也可以进行类似封装........ // 组件的其他方法也可以进行类似封装........
}; };
$.fn.bootstrapTreeTable.defaults = { $.fn.bootstrapTreeTable.defaults = {
id : 'id',// 选取记录返回的值 id: 'id',// 选取记录返回的值
code : 'id',// 用于设置父子关系 code: 'id',// 用于设置父子关系
parentCode : 'parentId',// 用于设置父子关系 parentCode: 'parentId',// 用于设置父子关系
rootCodeValue: null,//设置根节点code值----可指定根节点,默认为null,"",0,"0" rootCodeValue: null,//设置根节点code值----可指定根节点,默认为null,"",0,"0"
data : [], // 构造table的数据集合 data: [], // 构造table的数据集合
type : "GET", // 请求数据的ajax类型 type: "GET", // 请求数据的ajax类型
url : null, // 请求数据的ajax的url url: null, // 请求数据的ajax的url
ajaxParams : {}, // 请求数据的ajax的data属性 ajaxParams: {}, // 请求数据的ajax的data属性
expandColumn : null,// 在哪一列上面显示展开按钮 expandColumn: null,// 在哪一列上面显示展开按钮
expandAll : true, // 是否全部展开 expandAll: true, // 是否全部展开
expandFirst : false, // 是否默认第一级展开--expandAll为false时生效 expandFirst: false, // 是否默认第一级展开--expandAll为false时生效
striped : false, // 是否各行渐变色 striped: false, // 是否各行渐变色
columns : [], columns: [],
toolbar: null,//顶部工具条 toolbar: null,//顶部工具条
height: 0, height: 0,
expanderExpandedClass : 'glyphicon glyphicon-chevron-down',// 展开的按钮的图标 expanderExpandedClass: 'glyphicon glyphicon-chevron-down',// 展开的按钮的图标
expanderCollapsedClass : 'glyphicon glyphicon-chevron-right'// 缩起的按钮的图标 expanderCollapsedClass: 'glyphicon glyphicon-chevron-right'// 缩起的按钮的图标
}; };
})(jQuery); })(jQuery);
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment