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 = $("
"); 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 = $("
"); var _tool_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 = $(''); 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 = $(''); if(column.radio){ var _ipt = $(''); td.append(_ipt); } if(column.checkbox){ var _ipt = $(''); td.append(_ipt); } tr.append(td); }else{ var 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 = $(''); $.each(options.columns, function(i, item) { var th = null; // 判断有没有选择列 if(i==0&&item.field=='selectItem'){ hasSelectItem = true; th = $(''); }else{ th = $(''); } th.text(item.title); thr.append(th); }); var thead = $(''); thead.append(thr); target.append(thead); // 构造表体 var tbody = $(''); target.append(tbody); // 添加加载loading var _loading = '
正在努力地加载数据中,请稍候……
' 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 = '
没有记录
' tbody.html(_empty); return; } var rootNode = target.getRootNodes(data); $.each(rootNode, function(i, item) { var 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.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 = '
'+xhr.responseText+'
' 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循环嵌套如图所示:

jquery.treegrid.extension.js第三方组件使用_第1张图片jquery.treegrid.extension.js第三方组件使用_第2张图片

清空之前的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 = $("
"); // var _tool_left_div = $("
"); // _tool_left_div.append($(options.toolbar)); // _tool_div.append(_tool_left_div); // _main_div.before(_tool_div); // }

完成后的页面显示效果为:

jquery.treegrid.extension.js第三方组件使用_第3张图片

 


阿里产品购买活动优惠劵链接:

https://promotion.aliyun.com/ntms/act/ambassador/sharetouser.html?userCode=bsu7swvn&utm_source=bsu7swvn

 

 

你可能感兴趣的:(js,前端)