1. 程式人生 > >jquery.treegrid.extension.js第三方元件使用

jquery.treegrid.extension.js第三方元件使用

(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);
        // }

完成後的頁面顯示效果為: