bootStrapTable;
$(function () { var oTable = new TableInit(); oTable.Init(); }); var TableInit = function () { var oTableInit = new Object(); oTableInit.Init = function () { $('#table').bootstrapTable({ url: '/xx/xx', //请求后台的URL(*) method: 'get', //请求方式(*) toolbar: '#toolbar', //工具按钮用哪个容器 striped: true, //是否显示行间隔色 cache: false, //是否使用缓存,默认为true,所以一般情况下需要设置一下这个属性(*) pagination: true, //是否显示分页(*) sortName: 'xx',// 默认排序字段 sortable: true, //是否启用排序 sortOrder: "asc", //排序方式 queryParams: oTableInit.queryParams,//传递参数(*) sidePagination: "server", //分页方式:client客户端分页,server服务端分页(*) pageNumber: 1, //初始化加载第一页,默认第一页 pageSize: 15, //每页的记录行数(*) pageList: [15, 25, 50, 100], //可供选择的每页的行数(*) search: false, //是否显示表格搜索,此搜索是客户端搜索,也可以是服务端检索 silent: true, strictSearch: true,//设置为 true启用全匹配搜索,否则为模糊搜索。 showColumns: false, //是否显示所有的列.前端可选择显示哪些列 showRefresh: false, //是否显示刷新按钮 minimumCountColumns: 2, //最少允许的列数 clickToSelect: true, //是否启用点击选中行 //height: 500, //行高,如果没有设置height属性,表格自动根据记录条数觉得表格高度 uniqueId: "customerId", //每一行的唯一标识,一般为主键列 showToggle: false, //是否显示详细视图和列表视图的切换按钮 cardView: false, //是否显示详细视图 detailView: false, //是否显示父子表 //得到查询的参数 queryParams: function (params) { //这里的键的名字和控制器的变量名必须一直,这边改动,控制器也需要改成一样的 var query_params = { limit: params.limit, //页面大小 offset: params.offset, //页码 sort: params.sort, //排序列名 order: params.order, //排位命令(desc,asc) //查询框中的参数传递给后台 xx: $('#xxId').val(), // 请求时向服务端传递的参数 }; return query_params; }, columns: [ { title: 'xxxx', field: 'xxName', align: "center", valign: 'middle', sortName: 'xx', sortable: true, formatter: function (value, row, index) { return [ '<a onclick="openEditDetailsModel("' + row.customerId + '","' + row.xx+ '","' + value + '")" style="cursor:pointer;" tabindex="0">' + value + '</a>' ].join(''); } }, { title: 'xx', field: 'xx', align: "center", valign: 'middle', sortName: 'xx', sortable: true } ] }); }; return oTableInit; };bootStrap Validator验证
function xxValidator() { // bootstrapValidator表单校验 $(".formClassName").bootstrapValidator({ feedbackIcons: { valid: 'glyphicon glyphicon-ok', invalid: 'glyphicon glyphicon-remove', validating: 'glyphicon glyphicon-refresh' }, fields: { checkName: { validators: { notEmpty: { message: 'errorMessage' }, stringLength: { /*长度提示*/ min: 1, max: 20, message: 'errorMessage' }, remote: { url: "/xx/xxx", data: function (validator) { return { checkName: $("#checkName").val(), }; }, message: 'errorMessage', delay: 10 }, callback: { message: "errorMessage", callback: function (value, validator) { for (var i = 0; i < allCheckName.length; i++) { if (value == allCheckName[i]) { return false; } } return true; } } } }, checkName: { validators: { notEmpty: { message: 'errorMessage' }, stringLength: { min: 1, max: 20, message: 'errorMessage' }, regexp: { regexp: /^([1-9]\d{0,15}|[0]{1,1})$/, message: 'errorMessage' } } } } }) // 有效日期格式 bootstrap validator 日期插件 验证. 日期插件点击需要重新更新验证 $("#dateId").on('change', function (e) { $('.formClassName').data('bootstrapValidator').updateStatus('checkName', 'NOT_VALIDATED', null).validateField('checkName'); }); }
bootstrap validator 验证:
前台的table或tr,input是js动态生成的,需要用到 addField
for (.................){
tr="..<input type=text id = inputId>..."
tr.append("....................");
tr.appendTo("....................")
// xxxxxxx:动态添加的元素例如:$("#inputId) 然后在$(".formClassName").bootstrapValidator({里面需要添加对应的校验信息内容规则})
$(".formClassName").bootstrapValidator('addField', xxxxxxx);}
验证完 关键之处:
// model关闭
$('#modeId').on('hidden.bs.modal', function () {// 清除动态添加的验证
$(".formClassName").bootstrapValidator('removeField', 'checkName');// 销毁验证
$(".formClassName).data('bootstrapValidator').destroy();// 重新加载验证
xxValidator();
// 重新刷新table
$('#tableId').bootstrapTable('refresh');}