重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要为大家展示了“bootstrap如何实现table插件动态加载表头”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“bootstrap如何实现table插件动态加载表头”这篇文章吧。
目前创新互联公司已为上千家的企业提供了网站建设、域名、雅安服务器托管、网站托管运营、企业网站设计、多伦网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。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插件动态加载表头”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联成都网站设计公司行业资讯频道!
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。