日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

本篇文章給大家介紹一下bootstrap table分頁的實現兩種方式。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。


淺談bootstrap table分頁的實現兩種方式


bootstrap table分頁的兩種方式:

前端分頁:一次性從數據庫查詢所有的數據,在前端進行分頁(數據量小的時候或者邏輯處理不復雜的話可以使用前端分頁)

服務器分頁:每次只查詢當前頁面加載所需要的那幾條數據

bootstrap 下載地址:http://www.bootcss.com/

bootstrap-table 下載地址:http://bootstrap-table.wenzhixin.net.cn/

jquery下載地址:http://www.bootcss.com/


分頁效果(請忽略樣式)


6078f869ec9c7.png


一:準備js、css等文件

將下載的文檔直接放入webapp目錄下


6078f89023b2f.png


頁面引入需要的js、css

<!-- 引入的css文件  -->
<link href="bootstrap/css/bootstrap.min.css" rel="stylesheet" />
<link href="bootstrap-table/dist/bootstrap-table.min.css" rel="stylesheet">
<!-- 引入的js文件 -->
<script src="jquery/jquery.min.js"></script>
<script src="bootstrap/js/bootstrap.min.js"></script>
<script src="bootstrap-table/dist/bootstrap-table.min.js"></script>
<script src="bootstrap-table/dist/locale/bootstrap-table-zh-CN.min.js"></script>

二:html頁面標簽內容


<div class="panel panel-default">
    <div class="panel-heading">
        查詢條件
    </div>
    <div class="panel-body form-group" style="margin-bottom:0px;">
        <label class="col-sm-1 control-label" style="text-align: right; margin-top:5px">姓名:</label>
        <div class="col-sm-2">
            <input type="text" class="form-control" name="Name" id="search_name"/>
        </div>
        <label class="col-sm-1 control-label" style="text-align: right; margin-top:5px">手機號:</label>
        <div class="col-sm-2">
            <input type="text" class="form-control" name="Name" id="search_tel"/>
        </div>
        <div class="col-sm-1 col-sm-offset-4">
            <button class="btn btn-primary" id="search_btn">查詢</button>
        </div>
     </div>
</div>
<table id="mytab" class="table table-hover"></table>

三:JS分頁代碼

$('#mytab').bootstrapTable({
    method : 'get',
    url : "user/getUserListPage",//請求路徑
    striped : true, //是否顯示行間隔色
    pageNumber : 1, //初始化加載第一頁
    pagination : true,//是否分頁
    sidePagination : 'client',//server:服務器端分頁|client:前端分頁
    pageSize : 4,//單頁記錄數
    pageList : [ 5, 10, 20, 30 ],//可選擇單頁記錄數
    showRefresh : true,//刷新按鈕
    queryParams : function(params) {//上傳服務器的參數
        var temp = {//如果是在服務器端實現分頁,limit、offset這兩個參數是必須的
            limit : params.limit, // 每頁顯示數量
            offset : params.offset, // SQL語句起始索引
            //page : (params.offset / params.limit) + 1, //當前頁碼 
  
            Name : $('#search_name').val(),
            Tel : $('#search_tel').val()
        };
        return temp;
    },
    columns : [ {
        title : '登錄名',
        field : 'loginName',
        sortable : true
    }, {
        title : '姓名',
        field : 'name',
        sortable : true
    }, {
        title : '手機號',
        field : 'tel',
    }, {
        title : '性別',
        field : 'sex',
        formatter : formatSex,//對返回的數據進行處理再顯示
    }, {
        title : '操作',
        field : 'id',
        formatter : operation,//對資源進行操作
    } ]
})
  
//value代表該列的值,row代表當前對象
function formatSex(value, row, index) {
    return value == 1 ? "男" : "女";
    //或者 return row.sex == 1 ? "男" : "女";
}
  
//刪除、編輯操作
function operation(value, row, index) {
    var htm = "<button>刪除</button><button>修改</button>"
    return htm;
}
  
//查詢按鈕事件
$('#search_btn').click(function() {
    $('#mytab').bootstrapTable('refresh', {
        url : 'user/getUserListPage'
    });
})

四:bootstrap-table 實現前端分頁

修改JS分頁代碼中某些屬性

sidePagination:'client',
queryParams : function (params) {
    var temp = {
        name:$('#search_name').val(),
        tel:$('#search_tel').val()
    };
    return temp;
},

定義user對象

package com.debo.common;
  
public class User {
     
    private Integer id;
    private String loginName;
    private String name;
    private String tel;
    private Integer sex;
     
        //省略Get/Set函數
}

服務器Controller層代碼

/**
*直接一次性查出所有的數據,返回給前端,bootstrap-table自行分頁
*/
@RequestMapping("/getUserListPage")
@ResponseBody
public List<User> getUserListPage(User user,HttpServletRequest request){
    List<User> list = userService.getUserListPage(user);
    return list;
}

mabatis語句

<select id="getUserListPage" resultType="com.debo.common.User">
    SELECT * FROM user WHERE 1 = 1
    <if test="name!=null and name !=''">
        AND name LIKE CONCAT('%',#{name},'%')
    </if>
    <if test="tel!=null and tel !=''">
        AND tel = #{tel}
    </if>
</select>

五:bootstrap-table 實現服務器端分頁

設置JS分頁代碼中的某些屬性

sidePagination:'server',
queryParams : function (params) {
    var temp = {
        limit : params.limit, // 每頁顯示數量
        offset : params.offset, // SQL語句起始索引
        page: (params.offset / params.limit) + 1,   //當前頁碼
             
        Name:$('#search_name').val(),
        Tel:$('#search_tel').val()
    };
    return temp;
},

封裝公共的page對象,并讓user對象繼承page對象

package com.debo.common;
  
public class Page {
    //每頁顯示數量
    private int limit;
    //頁碼
    private int page;
    //sql語句起始索引
    private int offset;
    public int getLimit() {
        return limit;
    }
    public void setLimit(int limit) {
        this.limit = limit;
    }
    public int getPage() {
        return page;
    }
    public void setPage(int page) {
        this.page = page;
    }
    public int getOffset() {
        return offset;
    }
    public void setOffset(int offset) {
        this.offset = offset;
    }
  
}
package com.debo.common;
  
public class User extends Page{
     
    private Integer id;
    private String loginName;
    private String name;
    private String tel;
    private Integer sex;
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getLoginName() {
        return loginName;
    }
    public void setLoginName(String loginName) {
        this.loginName = loginName;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getTel() {
        return tel;
    }
    public void setTel(String tel) {
        this.tel = tel;
    }
    public Integer getSex() {
        return sex;
    }
    public void setSex(Integer sex) {
        this.sex = sex;
    }
}

封裝返回數據實體類

package com.debo.common;
  
import java.util.ArrayList;
import java.util.List;
  
public class PageHelper<T> {
    //實體類集合
    private List<T> rows = new ArrayList<T>();
    //數據總條數
    private int total;
  
    public PageHelper() {
        super();
    }
  
    public List<T> getRows() {
        return rows;
    }
  
    public void setRows(List<T> rows) {
        this.rows = rows;
    }
  
    public int getTotal() {
        return total;
    }
  
    public void setTotal(int total) {
        this.total = total;
    }
  
}

服務器Controller層代碼

@RequestMapping("/getUserListPage")
@ResponseBody
public PageHelper<User> getUserListPage(User user,HttpServletRequest request) {
         
        PageHelper<User> pageHelper = new PageHelper<User>();
    // 統計總記錄數
    Integer total = userService.getTotal(user);
    pageHelper.setTotal(total);
  
    // 查詢當前頁實體對象
    List<User> list = userService.getUserListPage(user);
    pageHelper.setRows(list);
  
    return pageHelper;
}

mybatis語句

<select id="getTotal" resultType="int">
    SELECT count(1) FROM user WHERE 1 = 1
    <if test="name!=null and name !=''">
        AND name LIKE CONCAT('%',#{name},'%')
    </if>
    <if test="tel!=null and tel !=''">
        AND tel = #{tel}
    </if>
</select>
  
<select id="getUserListPage" resultType="com.debo.common.User">
    SELECT * FROM user WHERE 1 = 1
    <if test="name!=null and name !=''">
        AND name LIKE CONCAT('%',#{name},'%')
    </if>
    <if test="tel!=null and tel !=''">
        AND tel = #{tel}
    </if>
    LIMIT #{offset},#{limit}
</select>


tip:增、刪、改操作后重新加載表格

$("#mytab").bootstrapTable('refresh', {url : url});


分享到:
標簽:bootstrap table分頁 實現兩種方式
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定