它基于bootstarp实现的表格js插件。
中文官网地址:http://bootstrap-table.wenzhixin.net.cn/zh-cn/getting-started/
基于它实现的效果图
初始化有两种方式,一种通过data属性的方式配置,一种是javascipt方式配置,在官网有详细配置说明。
我在此采用的是js方式配置,不管采用那种方式,这里有个大坑,就是返回数据咋么也显示不出来,在网上查了好多资料才发现对json格式有要求。
{
"total": "10",
"rows": [
{
"name": "cs1"
},
{
"name": "cs2"
}
]
}
说明:total:数据总条数(用作翻页时使用) , rows:页面展示json数组
我这里采用的是data-url方式,在页面中写好table的thead,tbody则由botstraptable动态生成。
说明:
data-field : json对应表格中的字段,它的值就是json的每个字段的key
data-formatter :它的值是一个自定义方法名,作用是格式化显示字段
data-align : 文字对齐格式
var _table = $('#table');
//初始化bootstrap table ,并且启动它
function init(){
_table.bootstrapTable({
url: '${basePath}sys/website/list',
method: 'get',
pagination: true, //表格底部显示分页条
sidePagination: "server",
escape:false, //启动转义字符
pageSize: 10, //每页显示多少条数据
pageNumber: 1, //初始化翻页的页码
pageList: [10, 25, 50, 100],
queryParamsType:'',//设置请求参数格式
queryParams:function queryParams(params) { //设自定义查询参数
var param = {
pageSize: params.pageSize, //每页多少条数据
pageIndex: params.pageNumber, // 页码
sysWebsiteTitle: $("#sysWebsiteTitle").val(),//菜单标题
sysCategoryId: $("#sysCategoryId").val() //网址分类id
};
return param;
}
});
}
$(function(){
init();//启动表格插件
});
说明:
url:获取后台的json数据
一般表格最后一个字段都是放操作的按钮(请看第一张效果图)
//格式化参数列
function init_format(value, row, index) {
var id = row.sysWebsiteId;
var html = "";
html += "";
html += "";
return html;
}
方法说明: 形参是value:占位(必须有,暂时没搞懂),row:每行遍历的json对象,index:当前行的下标
在列表页面中总会有多个查询条件需求,采用这个插件后如何实现自定义插件?
这个插件有一个开启条件查询的配置项,但是它只有一个条件查询,无法满足多条件查询,所有自能自定义查询参数。
在上边的 2.3 js初始化配置中,配置中的param是json对象,key是请求参数中的name,value是请求参数中的值
queryParamsType:'',//设置请求参数格式
queryParams:function queryParams(params) { //设自定义查询参数
var param = {
pageSize: params.pageSize, //每页多少条数据
pageIndex: params.pageNumber, // 页码
sysWebsiteTitle: $("#sysWebsiteTitle").val(),//菜单标题
sysCategoryId: $("#sysCategoryId").val() //网址分类id
};
return param;
}
说明:
queryParamsType:' ',必须配置
params:中会记录当前的页码和每页显示多少条数据
请求参数配置好后,实现条件查询,我的实现思路是
//刷新 bootstrap table 方法 翻页下标重置为1
function refreshData() {
_table.bootstrapTable('refresh',{
pageNumber: 1,
});
}
说明: _table是插件对象
我的实现思路是,输入查询条件,点击查询按钮调用刷新插件的方法(刷新插件,之前设置过自定义请求参数,此处会携带请求参数),插件重新请求后台url地址。
案例中只实现了一个条件,多条件继续添加请求参数就可以了