记录一下 bootstrap-table插件的使用

先看下效果图

  1. 首先是导入js

    <!--js jquery -->
    <script type="text/javascript" src="${pageContext.request.contextPath}/js/jquery-1.9.0.min.js"></script>
    <!--js bootstrap -->
    <script src="${pageContext.request.contextPath}/bootstrapJs/bootstrap.min.js"></script>
    <!-- js bootstrap-table 分页插件 -->
    <script type="text/javascript"src="${pageContext.request.contextPath}/js/bootstrap-table.js"></script>
    <script src="${pageContext.request.contextPath}/bootstrapJs/table/bootstrap-table-zh-CN.js"></script>
    <!-- js bootstrap-datetimepicker 时间插件 -->
    <script src="${pageContext.request.contextPath}/bootstrapJs/datetimepicker/bootstrap-datetimepicker.min.js"></script>
    <script src="${pageContext.request.contextPath}/bootstrapJs/datetimepicker/bootstrap-datetimepicker.zh-CN.js"></script>
    <!-- js knockout 增删改查 插件 -->
    <script src="https://cdn.bootcss.com/knockout/3.4.0/knockout-min.js"></script>
    <script src="${pageContext.request.contextPath}/bootstrapJs/knockout/knockout.mapping-latest.js"></script>
    <!-- css -->
    <link href="${pageContext.request.contextPath}/css/bootstrap-table.css"rel="stylesheet" type="text/css" />
    <link href="${pageContext.request.contextPath}/bootstrapCss/datetimepicker/bootstrap-datetimepicker.min.css" rel="stylesheet" />

      

  2. 在页面上增加标签,  分页标签有两种方式一种是自己在页面上写,一种是在js中自定义,我选择的是第一种
    <div class="panel-body" style="padding-bottom: 0px;" id="shouRu">
    <div class="panel panel-default">
    <div class="panel-heading">收入类目查询条件</div>
    <div class="panel-body">
    <form id="formSearch" class="form-horizontal">
    <div class="form-group" style="margin-top: 15px">
    <label class="control-label col-sm-1"
    for="txt_search_departmentname">日期:</label>
    <div class="col-sm-3">
    <input placeholder="开始日期" class="form-control layer-date" id="start" name="startDate">
    </div>
    <div class="col-sm-3">
    <input placeholder="结束日期" class="form-control layer-date" id="end" name="endDate">
    </div>
    <div class="col-sm-4" style="text-align: left;">
    <button type="button" style="margin-left: 50px" id="btn_query"
    class="btn" onclick="show();">查询</button>
    </div>
    <span style="display: none" id="span">1</span>
    </div>
    </form>
    </div>
    </div> <div id="toolbar" class="btn-group">
    <button id="btn_add" type="button" class="btn btn-default">
    <span class="glyphicon glyphicon-plus" aria-hidden="true"></span>新增
    </button>
    <button id="btn_delete" type="button" class="btn btn-default">
    <span class="glyphicon glyphicon-remove" aria-hidden="true"></span>删除
    </button>
    </div>
    <table id="tb_departments" data-bind="myBootstrapTable:$root"></table>
    </div>

      

  3. 写js
    $(function() {
    // 1.初始化Table
    var oTable = new TableInit();
    oTable.Init();
    }); //定义table显示样式 和后台交互的url
    var TableInit = function() {
    var oTableInit = new Object();
    // 初始化Table
    oTableInit.Init = function() {
    $("#tb_departments").bootstrapTable('destroy');
    $('#tb_departments').bootstrapTable({
    url : '/billMaven/categoryselect', // 请求后台的URL(*)
    method : 'get', // 请求方式(*)
    toolbar : '#toolbar', // 工具按钮用哪个容器
    striped : true, // 是否显示行间隔色
    cache : false, // 是否使用缓存,默认为true,所以一般情况下需要设置一下这个属性(*)
    pagination : true, // 是否显示分页(*)
    sortable : false, // 是否启用排序
    sortOrder : "asc", // 排序方式
    sidePagination : "server", // 分页方式:client客户端分页,server服务端分页(*)
    pageNumber : 1, // 初始化加载第一页,默认第一页
    pageSize : 10, // 每页的记录行数(*)
    pageList : [ 10, 25, 50, 100 ], // 可供选择的每页的行数(*)
    search : true, // 是否显示表格搜索,此搜索是客户端搜索,不会进服务端,所以,个人感觉意义不大
    strictSearch : true,
    showColumns : true, // 是否显示所有的列
    showRefresh : false, // 是否显示刷新按钮
    minimumCountColumns : 1, // 最少允许的列数
    clickToSelect : true, // 是否启用点击选中行
    height : 400, // 行高,如果没有设置height属性,表格自动根据记录条数觉得表格高度
    uniqueId : "id", // 每一行的唯一标识,一般为主键列
    showToggle : true, // 是否显示详细视图和列表视图的切换按钮
    cardView : false, // 是否显示详细视图
    detailView : false, // 是否显示父子表
    queryParamsType : "", //我使用的是向后台传输 page和size 还有另一种方式,请自行百度
    queryParams : oTableInit.queryParams,
    columns : [ {
    checkbox : true
    }, {
    field : 'id', //对应返回的名称
    title : 'id' //自定义名称
    }, {
    field : 'billname',
    title : '收入类目名称'
    }, {
    field : 'creatime',
    title : '类目创建时间', //因为后台返回的时间是时间戳 所以要转换成我们平常看到的日期
    formatter : function(value, row, index) {
    return fmtDate(value)
    }
    }, {
    title : '操作',
    align : 'center',
    formatter : operateFormatter //自定义修改和删除标志 也可以不写
    }, ],
    formatNoMatches: function(){
    return "没有相关的匹配结果";
    }, formatLoadingMessage: function(){
    return "请稍等,正在加载中。。。";
    }
    });
    };
    function fmtDate(obj) { //时间转换的方法
    var date = new Date(obj);
    var y = 1900 + date.getYear();
    var m = "0" + (date.getMonth() + 1);
    var d = "0" + date.getDate();
    var h = date.getHours();
    var mm = date.getMinutes();
    var s = date.getSeconds();
    return y + "-" + m.substring(m.length - 2, m.length) + "-"
    + d.substring(d.length - 2, d.length) + " " + h + ":" + mm
    + ":" + s;
    }
    // 得到查询的参数 条件查询
    oTableInit.queryParams = function(params) {
    var temp = { // 这里的键的名字和控制器的变量名必须一直,这边改动,控制器也需要改成一样的
    size: params.pageSize, // 页面大小
    page: params.pageNumber, // 页码
    startdate : $("#start").val(),
    enddate : $("#end").val(),
    statu : $("#span").html()
    };
    return temp;
    };
    return oTableInit;
    }; var ButtonInit = function() {
    var oInit = new Object();
    var postdata = {}; oInit.Init = function() {
    var oTable = new TableInit();
    oTable.Init();
    }; return oInit;
    };
    //页面上的查询按钮点击事件
    function show() {
    // 2.初始化Button的点击事件
    var oButtonInit = new ButtonInit();
    oButtonInit.Init(); }  
     //操作按钮定义

    function operateFormatter(value, row, index) {
    return [
    '<a class="like" href="javascript:void(0)" title="Update" onclick="remove()">',
    '<i class="glyphicon glyphicon-heart" onclick="remove()"></i>',
    '</a> ',
    '<a class="remove" href="javascript:void(0)" title="Remove">',
    '<i class="glyphicon glyphicon-remove"></i>', '</a>' ].join('');
    }

bootstrap-table 分页增删改查之一(分页)的更多相关文章

  1. 用SpringBoot+MySql+JPA实现对数据库的增删改查和分页

    使用SpringBoot+Mysql+JPA实现对数据库的增删改查和分页      JPA是Java Persistence API的简称,中文名Java持久层API,是JDK 5.0注解或XML描述 ...

  2. SpringBoot JPA实现增删改查、分页、排序、事务操作等功能

    今天给大家介绍一下SpringBoot中JPA的一些常用操作,例如:增删改查.分页.排序.事务操作等功能.下面先来介绍一下JPA中一些常用的查询操作: //And --- 等价于 SQL 中的 and ...

  3. SpringBoot-Vue实现增删改查及分页小DEMO

    前言 主要通过后端 Spring Boot 技术和前端 Vue 技术来简单开发一个demo,实现增删改查.分页功能以及了解Springboot搭配vue完成前后端分离项目的开发流程. 开发栈 前端 开 ...

  4. 【BootStrap】--具有增删改查功能的表格Demo

    [BootStrap]--具有增删改查功能的表格Demo 目录(?)[+] 前言 版本一 样式 代码 版本二 样式 代码 版本三 样式 代码 总结 前言 bootstrap的表格样式,有类似EasyU ...

  5. MYSQL - database 以及 table 的增删改查

    MYSQL - database 以及 table 的增删改查 MySQL的相关概念介绍 MySQL 为关系型数据库(Relational Database Management System), 这 ...

  6. bootstrap-table 分页增删改查之一(增加 删除)

    先上效果图 引入js文件 <!--js jquery --> <script type="text/javascript" src="${pageCon ...

  7. springDataJPQL实现增删改查及分页,原生sql查询,根据方法命名规则实现查询以及Specification查询

    一.使用方法 1.在dao中定义开一个方法,使用方法的参数设置jpql,并且使用方法的返回值接受查询结果,在方法上添加@query注解,在注解中写jpql语句进行增删改查,测试 2.使用原生的sql语 ...

  8. Magicodes.WeiChat——ASP.NET Scaffolding生成增删改查、分页、搜索、删除确认、批量操作、批量删除等业务代码

    关于T4代码生成这块,我之前写过几篇帖子,如:<Magicodes.NET框架之路——让代码再飞一会(ASP.NET Scaffolding)>(http://www.cnblogs.co ...

  9. JavaWeb学习记录(七)——MVC操作数据库增删改查与分页功能

    一.分页工具类 package blank.util;import java.util.List; import org.springframework.jdbc.core.JdbcTemplate; ...

随机推荐

  1. springcloud eureka注册中心 高可复用。

    1:新建两个注册中心项目(名称都为:spring-cloud-eureka,只是端口分别为8000.8001 ).两个注册中心相互注册对方. 2:两个注册中心都启动后,则对方服务列表都有对方的服务. ...

  2. trace跟踪代码运行

    System.Diagnostics命名空间中. 1.Trace.Assert(a==12,"等于就不输出,不等于弹出对话框");   名称 描述   Assert(Boolean ...

  3. [Xamarin.Android]使用Java Bindings Libary專案 Binding Java元件(.jar) 與Metadata.xml、型別對應 (转帖)

    使用Xamarin開發Android APP時, 如果已經有原本就用Java寫好的套件(.jar), 就可以利用Xamarin提供的Java Bindings Libary將他變成C#可使用的元件. ...

  4. JDK1.7新特性(3):java语言动态性之脚本语言API

    简要描述:其实在jdk1.6中就引入了支持脚本语言的API.这使得java能够很轻松的调用其他脚本语言.具体API的使用参考下面的代码: package com.rampage.jdk7.chapte ...

  5. SQL:存储过程

    1/什么是存储过程及概念 Transact-SQL中的存储过程,非常类似于.Net语言中的方法,它可以重复调用.当存储过程执行一次后,可以将语句缓存中,这样下次执行的时候直接使用缓存中的语句.这样就可 ...

  6. shell 10个好习惯

    The Linux Cookbook 一书的作者 Michael Stutz 凭借自己多年使用 UNIX 的经验,总结了 10 个良好习惯,个人认为真的很受用,现摘要如下与大家分享. 1.建立层级目录 ...

  7. VM虚拟机安装后的网络设置

    -------------------------------------------- VM的win7系统 网络设置: 1,启动前,VM中的 网络适配器:NAT 2,关闭主机和虚拟机的所有防火墙先. ...

  8. FE面试题库

    一.HTML 序号 面试题目 难度等级 回答要点 H1 简述编写HTML需要注意哪些事项? ☆ DOCTYPE.charset.viewport.语义化.CSS与JS的位置.DOM层级.结构样式行为的 ...

  9. C#中区别多态、重载、重写

    重写是指重写基类的方法,在基类中的方法必须有修饰符virtual,而在子类的方法中必须指明override. 格式: 基类中: public virtual void myMethod() { } 子 ...

  10. 一:XML知识整理

    一:xml 1. xml简介 a) xml, eXtensible Markup Language, 可扩展标记语言.是一种标记语言. b) xml 是一种非常灵活的语言, 没有固定的标签, 所有的标 ...