首页前端开发其他前端知识Bootstrap中怎么实现table分页,有什么方法

Bootstrap中怎么实现table分页,有什么方法

时间2024-03-27 13:54:03发布访客分类其他前端知识浏览742
导读:在这篇文章中,我们将学习“Bootstrap中怎么实现table分页,有什么方法”的相关知识,下文有详细的介绍及示例,小编觉得挺不错的,有需要的朋友可以借鉴参考,希望对大家阅读完这篇能有所获。 本篇文章给大家介绍两种boot...
在这篇文章中,我们将学习“Bootstrap中怎么实现table分页,有什么方法”的相关知识,下文有详细的介绍及示例,小编觉得挺不错的,有需要的朋友可以借鉴参考,希望对大家阅读完这篇能有所获。

本篇文章给大家介绍两种bootstrap table分页的方式。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

bootstrap table分页的两种方式:

前端分页:一次性从数据库查询所有的数据,在前端进行分页(数据量小的时候或者逻辑处理不复杂的话可以使用前端分页)

服务器分页:每次只查询当前页面加载所需要的那几条数据

一:准备js、css等文件

▶ 将下载的文档直接放入webapp目录下

▶页面引入需要的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 ListUser>
 getUserListPage(User user,HttpServletRequest request){
    
	ListUser>
     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 PageHelperT>
 {
    
    //实体类集合
    private ListT>
     rows = new ArrayListT>
    ();
    
    //数据总条数
    private int total;

 
    public PageHelper() {
    
        super();

    }
    
 
    public ListT>
 getRows() {
    
        return rows;

    }
    
 
    public void setRows(ListT>
 rows) {
    
        this.rows = rows;

    }

 
    public int getTotal() {
    
        return total;

    }

 
    public void setTotal(int total) {
    
        this.total = total;

    }

 
}
    

▶ 服务器Controller层代码

@RequestMapping("/getUserListPage")
@ResponseBody
public PageHelperUser>
 getUserListPage(User user,HttpServletRequest request) {
    
		
        PageHelperUser>
     pageHelper = new PageHelperUser>
    ();
    
	// 统计总记录数
	Integer total = userService.getTotal(user);
    
	pageHelper.setTotal(total);
    
 
	// 查询当前页实体对象
	ListUser>
     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分页,有什么方法的介绍,本文内容仅供参考,有需要的朋友可以借鉴了解看看,希望对大家学习或工作,想要了解更多欢迎关注网络,小编每天都会为大家更新不同的知识。

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: Bootstrap中怎么实现table分页,有什么方法
本文地址: https://pptw.com/jishu/654262.html
Java三大特性分别是什么,怎么理解 Bootstrap有何作用,应用场景是什么

游客 回复需填写必要信息