原文地址:https://blog.csdn.net/abubu123/article/details/78060321

bootstrap的table属性已经很熟悉了,最近遇到一个问题,犹豫每个列表加载的数据需求不同,所以需要动态的更换表头。 网上有很多加载表格数据的例子,但是却没有找到如何动态加载表格,再加在数据。 虽然可以一个表格加载一种数据,但是本着学习的态度尝试了下这种方式,结果发现是可以执行的。分享下思路和实现过程,以备日后使用。

思路:

1、写接口,查询出要展示的列。注意接口中必须要有字段中文名称(columns属性的title值),字段的英文名称(columns的field字段),特别注意filed字段应该与最后查询出的列表中返回的json数据中的key保持一致,不然取不到值。

2、ajax请求刚才的接口,查询出columns,并给table的columns赋值。

3、加载表格展示。

大致代码如下:

表格:

var peopleOptions;
    // 人口列表加载
    function tableItem() {
        peopleOptions = {
            method : "POST", // 使用get请求到服务器获取数据
            url : path + "/api/information/people/getList", // 获取数据的地址
            contentType : "application/x-www-form-urlencoded",// 重要否则POST会报错
            striped : false, // 表格显示条纹
            pagination : true, // 启动分页
            pageSize : 10, // 每页显示的记录数
            pageNumber : 1, // 当前第几页
            pageList : [ 10, 20, 50 ], // 记录数可选列表
            uniqueId : "id",
            showColumns : false, // 显示下拉框勾选要显示的列
            showToggle : false, // 显示 切换试图(table/card)按钮
            clickToSelect : false, // 点击可选
            singleSelect : false, // 禁止多选
            maintainSelected : true, // 在点击分页按钮或搜索按钮时,将记住checkbox的选择项
            sortable : true, // 禁止所有列的排序
            sidePagination : "server", // 表示服务端请求 后台分页
            toolbar : "#toolbar",// 指明自定义的toolbar
            queryParamsType : "undefined",
            queryParams : function queryParams(params) {
                var param = {
                    pageNumber : params.pageNumber,
                    pageSize : params.pageSize,
                    orgId : ztreeId,
                    nodeId : ztreeId,
                    citizenName : $("#fullname").val().trim(),
                    sex : $("#sex").val(),
                    age : $("#age").val().trim(),
                    identityCode : $("#idCard").val().trim(),
                    cellPhone : $("#isMobile").val().trim(),
                    adress : $("#adress").val().trim(),
                };
                return param;
            },
            onLoadSuccess : function() { // 加载成功时执行
                responseHandler : function(res) { // 格式化数据
                    console.log(res);
                    if (res.data.total != undefined)
                        tmp = {
                            total : res.data.total,
                            rows : res.data.rows
                        };
                    if (res.data.total == undefined)
                        tmp = {
                            total : res.data.length,
                            rows : res.data
                        };
                    return tmp;
                },
                columns : [ {
                    checkbox : true,
                    title : '全选',
                    valign : 'middle'
                }, {
                    title : '序号',
                    field : 'number',
                    width : '40px',
                    align : 'center',
                    valign : 'middle',
                    formatter : indexFormatter
                }, {
                    title : '姓名',
                    field : 'citizenName',
                    align : 'center',
                    valign : 'middle',
                },  {
                    title : '年龄',
                    field : 'age',
                    align : 'center',
                    width : 28,
                    valign : 'middle',
                    formatter : ageFormatter
                }, {
                    title : '性别',
                    field : 'sex',
                    width : 28,
                    align : 'center',
                    valign : 'middle',
                },{
                    title : '身份证号',
                    field : 'identityCode',
                    align : 'center',
                    valign : 'middle',
                }, {
                    title : '民族',
                    field : 'nation',
                    align : 'center',
                    valign : 'middle',
                } ]
            }
    }
        $table = $("#table").bootstrapTable(peopleOptions);
    };

动态获取列:

function getColumns() {
        // 加载动态表格
        $.ajax({
            url : path + "api/information/people/getLableColumn?ztreeId=" + ztreeId,
            type : 'get',
            dataType : "json",
            async : false,
            success : function(returnValue) {
                // 未查询到相应的列,展示默认列
                if (returnValue.retCode == "0") {
                    //没查到列的时候把之前的列再给它
                    myColumns = $table.bootstrapTable('getOptions').columns[0];
                } else {
                    // 异步获取要动态生成的列
                    var arr = returnValue.data;
                    $.each(arr, function(i, item) {
                        myColumns.push({
                            "field" : item.labelColumnCode,
                            "title" : item.labelColumnName,
                            "hide" : true,
                            "align" : 'center',
                            "valign" : 'middle'
                        });
                    });
                }
                console.log(myColumns);
                return myColumns;
            }
        });
    }

刷新列表:

//点击左侧树后重新加载表格
        $table.bootstrapTable(  
                      "refreshOptions",  
                      {  
                        url : path + "/api/peopledataInfo/getPeopleInfoList", // 获取数据的地址
                        columns : myColumns,
                        
                      }  
              );
          }

需要注意的是bootstrap的table提供了两个刷新的方法,一个refresh,一个refreshOptions,前者只是刷新当前表格,后者会将表格中的组件全部更新一遍,因为我们替换了url和columns,所以需要调用后者。

展示效果:

动态加载表头其实就是类似Echart中动态加载数据的感觉一样,只是改变整个Option中的相关属性即可。

优点:代码量会大大减少,当我们要加载不同数据且样式一样的表格的时候可以采用这样的方式。

缺点:样式很难维护。前端人员不好定位bug,所以很难修改相应的样式bug。

依据项目实际情况,择优使用吧。

[转]bootstrap的table插件动态加载表头的更多相关文章

  1. bootstrap table插件动态加载表头

    这篇文章主要为大家详细介绍了bootstrap table插件动态加载表头,具有一定的参考价值,感兴趣的小伙伴们可以参考一下   bootstrap的table属性已经很熟悉了,最近遇到一个问题,犹豫 ...

  2. 项目总结—jQuery EasyUI-DataGrid动态加载表头

    http://blog.csdn.net/zwk626542417/article/details/19248747 概要 在前面两篇文章中,我们已经介绍了在jQuery EasyUI-DataGri ...

  3. jQuery EasyUI-DataGrid动态加载表头

    项目总结—jQuery EasyUI-DataGrid动态加载表头     目录(?)[-] 概要 实现 总结   概要 在前面两篇文章中,我们已经介绍了在jQuery EasyUI-DataGrid ...

  4. js插件动态加载js、css解决方案

    最近因为工作需要做了一个js自动导入的插件,一开始很天真的以为动态创建个script添加到head中就ok了,试了之后才发现了问题,就是如果同时引入了多个js文件,而且后一个文件中用到了前一个文件中的 ...

  5. zTree树插件动态加载

    需求: 由于项目中家谱图数据量超大,而一般加载方式是通过,页面加载时 zTree.init方法进行数据加载,将所有数据一次性加载到页面中.而在项目中家谱级别又非常广而深,成千上万级,因此一次加载,完全 ...

  6. EasyUI datagrid 动态加载表头和数据

    首先返回到页面的需要是JSON数据: 第一步: 遍历表头,插入到array中 for (var i = 0; i < jsonObj.title.length; i++) { //把返回的数据封 ...

  7. C# 实现动态加载DLL插件 及HRESULT:0x80131047处理

    本代码实现DLL的动态加载, 类似PS里的滤镜插件! 1. 建立一个接口项目类库,此处名称为:Test.IPlugin using System; namespace Test.IPlugin { p ...

  8. 动态加载DataGrid表头及数据

    初始化表头 js生成前端 /*初始化表头*/ function initDataGridTitle(id) { $.ajax({ url: '/${appName}/report/***/***', ...

  9. Bootstrap Table表格一直加载(load)不了数据-解决办法

    bootstrap-table是一个基于Bootstrap风格的强大的表格插件神器,官网:http://bootstrap-table.wenzhixin.net.cn/zh-cn/ 这里列出遇到的一 ...

随机推荐

  1. MyBatis---使用MyBatis Generator生成Dto、Dao、Mapping

    由于MyBatis属于一种半自动的ORM框架,所以主要的工作将是书写Mapping映射文件,但是由于手写映射文件很容易出错,所以查资料发现有现成的工具可以自动生成底层模型类.Dao接口类甚至Mappi ...

  2. 【struts2】Struts2的异常处理

    在Action中execute方法声明为:public String execute() throws Exception,这样,Action可以抛出任何Exception. 1)自己实现异常处理 我 ...

  3. 【struts2】名为chain的ResultType

    1)基本使用 名称为“chain”的ResultType,在struts-default.xml里的配置如下: <result-type name="chain" class ...

  4. 如何从40亿整数中找到不存在的一个 webservice Asp.Net Core 轻松学-10分钟使用EFCore连接MSSQL数据库 WPF实战案例-打印 RabbitMQ与.net core(五) topic类型 与 headers类型 的Exchange

    如何从40亿整数中找到不存在的一个 前言 给定一个最多包含40亿个随机排列的32位的顺序整数的顺序文件,找出一个不在文件中的32位整数.(在文件中至少确实一个这样的数-为什么?).在具有足够内存的情况 ...

  5. 使用 TensorFlow 的起始步骤

    1 学习目标: 学习基本的 TensorFlow 概念 在 TensorFlow 中使用 LinearRegressor 类并基于单个输入特征预测各城市街区的房屋价值中位数 使用均方根误差 (RMSE ...

  6. MySQL表名不区分大小写的设置方法

    原来Linux下的MySQL默认是区分表名大小写的,通过如下设置,可以让MySQL不区分表名大小写:1.用root登录,修改 /etc/my.cnf:2.在[mysqld]节点下,加入一行: lowe ...

  7. Win7 64bit 安装VisualSVN出现报错:Servic &#39;VisualSVN Server&#39; failed to start.解决的方法

    问题描写叙述: Win7 64bit 安装VisualSVN时出现报错: Servic 'VisualSVN Server' failed to start.Please check VisualSV ...

  8. SQLServer2012 (非)聚集索引存储探究

    SQLServer2012 (非)聚集索引存储探究 Author:zfive5(zidong) Email:zfive5@163.com 引子 因为写了前一篇文字<SQLServer2012 表 ...

  9. ElementUI 按需引入坑爹的点记录

    官网说的是这样的: 但实际上,应该是这样修改: { "presets": [ ["env", { "targets": { "br ...

  10. C#基础课程之四集合(ArrayList、List<泛型>)

    list泛型的使用 ArrayList list = new ArrayList(); ArrayList list = ); //可变数组 list.Add("我"); //Ad ...