jquery.treegrid.extension.js第三方元件使用
阿新 • • 發佈:2019-01-24
(function($) { "use strict"; $.fn.bootstrapTreeTable = function(options, param) { // 如果是呼叫方法 if (typeof options == 'string') { return $.fn.bootstrapTreeTable.methods[options](this, param); } // 如果是初始化元件 options = $.extend({}, $.fn.bootstrapTreeTable.defaults, options || {}); // 是否有radio或checkbox var hasSelectItem = false; var target = $(this); // 在外層包裝一下div,樣式用的bootstrap-table的 //16行 var _main_div = $("<div class='fixed-table-container'></div>"); target.before(_main_div); _main_div.append(target); target.addClass("table table-hover treegrid-table table-bordered"); if (options.striped) { target.addClass('table-striped'); } // 工具條在外層包裝一下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)); _tool_div.append(_tool_left_div); _main_div.before(_tool_div); } // 得到根節點 target.getRootNodes = function(data) { // 指定Root節點值 var _root = options.rootCodeValue?options.rootCodeValue:null var result = []; $.each(data, function(index, item) { // 這裡相容幾種常見Root節點寫法 // 預設的幾種判斷 var _defaultRootFlag = item[options.parentCode] == '0' || item[options.parentCode] == 0 || item[options.parentCode] == null || item[options.parentCode] == ''; if (!item[options.parentCode] || (_root?(item[options.parentCode] == options.rootCodeValue):_defaultRootFlag)){ result.push(item); } // 新增一個預設屬性,用來判斷當前節點有沒有被顯示 item.isShow = false; }); return result; }; var j = 0; // 遞迴獲取子節點並且設定子節點 target.getChildNodes = function(data, parentNode, parentIndex, tbody) { $.each(data, function(i, item) { if (item[options.parentCode] == parentNode[options.code]) { var tr = $('<tr></tr>'); var nowParentIndex = (parentIndex + (j++) + 1); tr.addClass('treegrid-' + nowParentIndex); tr.addClass('treegrid-parent-' + parentIndex); target.renderRow(tr,item); item.isShow = true; tbody.append(tr); target.getChildNodes(data, item, nowParentIndex, tbody) } }); }; // 繪製行 target.renderRow = function(tr,item){ $.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 style="'+((column.width)?('width:'+column.width):'')+'"></td>'); // 增加formatter渲染 if (column.formatter) { td.html(column.formatter.call(this, item, index)); } else { td.text(item[column.field]); } tr.append(td); } }); } // 載入資料 target.load = function(parms){ // 載入資料前先清空 target.html(""); // 構造表頭 var thr = $('<tr></tr>'); $.each(options.columns, function(i, item) { var th = null; // 判斷有沒有選擇列 if(i==0&&item.field=='selectItem'){ hasSelectItem = true; th = $('<th style="width:36px"></th>'); }else{ th = $('<th style="padding:10px;'+((item.width)?('width:'+item.width):'')+'"></th>'); } th.text(item.title); thr.append(th); }); var thead = $('<thead class="treegrid-thead"></thead>'); thead.append(thr); target.append(thead); // 構造表體 var tbody = $('<tbody class="treegrid-tbody"></tbody>'); target.append(tbody); // 新增載入loading var _loading = '<tr><td colspan="'+options.columns.length+'"><div style="display: block;text-align: center;">正在努力地載入資料中,請稍候……</div></td></tr>' tbody.html(_loading); // 預設高度 if(options.height){ tbody.css("height",options.height); } $.ajax({ type : options.type, url : options.url, data : parms?parms:options.ajaxParams, dataType : "JSON", success : function(data, textStatus, jqXHR) { // 載入完資料先清空 tbody.html(""); if(!data||data.length<=0){ var _empty = '<tr><td colspan="'+options.columns.length+'"><div style="display: block;text-align: center;">沒有記錄</div></td></tr>' tbody.html(_empty); return; } var rootNode = target.getRootNodes(data); $.each(rootNode, function(i, item) { var tr = $('<tr></tr>'); tr.addClass('treegrid-' + (j + "_" + i)); target.renderRow(tr,item); item.isShow = true; tbody.append(tr); target.getChildNodes(data, item, (j + "_" + i), tbody); }); // 下邊的操作主要是為了查詢時讓一些沒有根節點的節點顯示 $.each(data, function(i, item) { if(!item.isShow){ var tr = $('<tr></tr>'); tr.addClass('treegrid-' + (j + "_" + i)); target.renderRow(tr,item); tbody.append(tr); } }); target.append(tbody); // 初始化treegrid target.treegrid({ treeColumn: options.expandColumn?options.expandColumn:(hasSelectItem?1:0),//如果有radio或checkbox預設第二列層級顯示,當前是在使用者未設定的提前下 expanderExpandedClass : options.expanderExpandedClass, expanderCollapsedClass : options.expanderCollapsedClass }); if (!options.expandAll) { target.treegrid('collapseAll'); } //動態設定表頭寬度 //thead.css("width", tbody.children(":first").css("width")); // 行點選選中事件 target.find("tbody").find("tr").click(function(){ if(hasSelectItem){ var _ipt = $(this).find("input[name='select_item']"); if(_ipt.attr("type")=="radio"){ _ipt.prop('checked',true); target.find("tbody").find("tr").removeClass("treegrid-selected"); $(this).addClass("treegrid-selected"); }else{ if(_ipt.prop('checked')){ _ipt.prop('checked',false); $(this).removeClass("treegrid-selected"); }else{ _ipt.prop('checked',true); $(this).addClass("treegrid-selected"); } } } }); }, error:function(xhr,textStatus){ var _errorMsg = '<tr><td colspan="'+options.columns.length+'"><div style="display: block;text-align: center;">'+xhr.responseText+'</div></td></tr>' tbody.html(_errorMsg); debugger; }, }); } if (options.url) { target.load(); } else { // 也可以通過defaults裡面的data屬性通過傳遞一個數據集合進來對元件進行初始化....有興趣可以自己實現,思路和上述類似 } return target; }; // 元件方法封裝........ $.fn.bootstrapTreeTable.methods = { // 返回選中記錄的id(返回的id由配置中的id屬性指定) // 為了相容bootstrap-table的寫法,統一返回陣列,這裡只返回了指定的id getSelections : function(target, data) { // 所有被選中的記錄input var _ipt = target.find("tbody").find("tr").find("input[name='select_item']:checked"); var chk_value =[]; // 如果是radio if(_ipt.attr("type")=="radio"){ chk_value.push({id:_ipt.val()}); }else{ _ipt.each(function(_i,_item){ chk_value.push({id:$(_item).val()}); }); } return chk_value; }, // 重新整理記錄 refresh : function(target, parms) { if(parms){ target.load(parms); }else{ target.load(); } }, // 元件的其他方法也可以進行類似封裝........ }; $.fn.bootstrapTreeTable.defaults = { id : 'menuId',// 選取記錄返回的值 code : 'menuId',// 用於設定父子關係 parentCode : 'parentId',// 用於設定父子關係 rootCodeValue: null,//設定根節點code值----可指定根節點,預設為null,"",0,"0" data : [], // 構造table的資料集合 type : "GET", // 請求資料的ajax型別 url : null, // 請求資料的ajax的url ajaxParams : {}, // 請求資料的ajax的data屬性 expandColumn : null,// 在哪一列上面顯示展開按鈕 expandAll : true, // 是否全部展開 striped : false, // 是否各行漸變色 columns : [], toolbar: null,//頂部工具條 height: 0, expanderExpandedClass : 'glyphicon glyphicon-chevron-down',// 展開的按鈕的圖示 expanderCollapsedClass : 'glyphicon glyphicon-chevron-right'// 縮起的按鈕的圖示 }; })(jQuery);
options:宣告的一個變數,在方法內給賦值成為了物件;
點選查詢按鈕後出現的div巢狀迴圈
原因:
每次執行_main_div 變數的時候都會建立新的div且會追加到options物件中造成的div迴圈巢狀如圖所示:
清空之前的div有兩種方式,
一:remove掉所有的div,再重新獲取查詢後的結果,不過弊端比較多
二:修改當前js檔案使其不再建立新的div標籤,也就是在頁面進行改動選取class元素進行操作
修改如下:
//16行 var _main_div = $(".fixed-table-container"); // target.before(_main_div); // _main_div.append(target); target.addClass("table table-hover treegrid-table table-bordered"); if (options.striped) { target.addClass('table-striped'); } // 工具條在外層包裝一下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)); // _tool_div.append(_tool_left_div); // _main_div.before(_tool_div); // }
完成後的頁面顯示效果為: