jquery datatable 前端分页和后端分页例子

1 篇文章 0 订阅

datatable分页有两种方式,一是页面分页,二是服务端分页

废话不多说,直接上代码


<link rel="stylesheet"	href="${app}/static/media/css/jquery.dataTables.css">
<script src="${app}/static/media/js/jquery.dataTables.js"></script>

//这个是固定列用的
<link rel="stylesheet"
	href="${app}/static/media/FixedColumns-3.2.2/css/fixedColumns.dataTables.min.css">
<script	src="${app}/static/media/FixedColumns-3.2.2/js/dataTables.fixedColumns.min.js"></script>

页面分页

    <div class="col-sm-12">
		<table class="table table-hover" id="dataTable" border="1">
			<thead>
				<tr>
					<th class="">单元</th>
					<th class="">网格</th>
					<th class="">营业厅</th>
					<th class="">渠道经理</th>
					<th class="">渠道经理电话</th>
				</tr>
			</thead>
			<tbody></tbody>
		</table>
	</div>



<script type="text/javascript">
	/* numbers - 只有只有数字按钮
	 simple - 只有上一页、下一页两个按钮
	 simple_numbers - 除了上一页、下一页两个按钮还有页数按钮,Datatables默认是这个
	 full - 有四个按钮首页、上一页、下一页、末页
	 full_numbers - 除首页、上一页、下一页、末页四个按钮还有页数按钮
	 first_last_numbers - 除首页、末页两个按钮还有页数按钮 */

	$(function() {
		initTable();		
	})

	function initTable() {		
		$('#dataTable').DataTable({
			info : true,
			destroy : true,
			paging : true, //是否分页
			ordering : false, //是否排序
			searching : false, //结果搜索
			lengthChange : false,
			pagingType : "simple_numbers",
			displayLength : 50,//每页显示条数
			lengthMenu : [50,100],//调整每页显示条数--我隐藏了
			processing : true,//显示“处理中...” 
			bStateSave : true,
			scrollX : true,
			scrollY: "500px",
			scrollCollapse: true,
			bAutoWidth : true,
			fixedColumns : {
				//固定列的配置项
				leftColumns : 1//-1第一列不固定,默认固定第一列
				//leftColumns : 2
			//固定右边第一列
			},
			language : {
				"sProcessing" : "处理中...",
				"sLengthMenu" : "显示 _MENU_ 项结果",
				"sZeroRecords" : "没有匹配结果",
				"sInfo" : "显示第 _START_ 至 _END_ 项结果,共 _TOTAL_ 项",
				"sInfoEmpty" : "显示第 0 至 0 项结果,共 0 项",
				"sInfoFiltered" : "(由 _MAX_ 项结果过滤)",
				"sInfoPostFix" : "",
				"sSearch" : "搜索:",
				"sUrl" : "",
				"sEmptyTable" : "表中数据为空",
				"sLoadingRecords" : "载入中...",
				"sInfoThousands" : ",",
				"oPaginate" : {
					"sFirst" : "首页",
					"sPrevious" : "上页",
					"sNext" : "下页",
					"sLast" : "末页"
				}
			},
			ajax : {
				url : '/alad/test/list1',
				type : 'post',
				//dataType: "json",
				data : function(d) {
					d.stat_date = $("#stat_date").val();
				},
				dataSrc : '',
				/* dataSrc : function(result){
					return result.data1;
				}, */
			},
			columns : [
				{title:'营业厅',data:'YYT',className:''},
				{title:'单元',data:'DY',className:""},
				{title:'网格',data:'WG',className:''},
				{title:'渠道经理',data:'QDJL',className:''},
				{title:'渠道经理电话',data:'QDJLDH',className:''}				
				],
		});
		
		
	}

这种是前端分页,把所有数据查询出来,即直接把list传到前端即可;

服务端分页:

$(document).ready(function() {
		$('#dataTable').DataTable({
			info : true,
			destroy : true,
			paging : true, //是否分页
			ordering : false, //是否排序
			searching : false, //结果搜索
			lengthChange : false,
			pagingType : "full",
			displayLength : 50,//每页显示条数
			lengthMenu : [50,100],
			processing : true,//显示“处理中...” 
			bStateSave : false,
			scrollX : true,
			scrollY: "500px",//固定表头
			scrollCollapse: true,
			"bAutoWidth" : false,
			"sAjaxSource" : '/alad/test/list2', //请求资源路径
			"serverSide" : true, //开启服务器处理模式
			fixedColumns : {
				//固定列的配置项
				leftColumns : 1//-1第一列不固定,默认固定第一列
				//leftColumns : 2
			//固定右边第一列
			},
			language : {
				url : '/alad/static/media/language.json'
			},
			/*
			使用ajax,在服务端处理数据
			sSource:即是"sAjaxSource"
			aoData:要传递到服务端的参数
			fnCallback:处理返回数据的回调函数
			 */
			"fnServerData" : function(sSource, aoData, fnCallback) {
				$.ajax({
					'type' : 'post',
					"url" : sSource,
					"dataType" : "json",
					"data" : {
						"aodata" : JSON.stringify(aoData),
						"stat_date" : $("#stat_date").val()
					},
					"success" : function(resp) {
						fnCallback(resp);
					}
				});
			},
			"columns" : [
				{title:'营业厅',data:'YYT'},
				{title:'单元',data:'DY'},
				{title:'网格',data:'WG'},
				{title:'渠道经理',data:'QDJL'},
				{title:'渠道经理电话',data:'QDJLDH'}				
			],
			columnDefs: [ //设置列的宽度,测试可以设置的比默认的长,减短会不行(或许我没弄对)
			       { 
			        render: function (data, type, full, meta) {
			         	return "<div class='text-wrap width-50'>" + data + "</div>"; 
			        }, 
			        targets: 3 
			       } 
			] 
		});
	})

 后端代码

@RequestMapping("list2")
	public void list2(HttpServletRequest request, HttpServletResponse response) {
		response.setCharacterEncoding("utf-8");
		PrintWriter writer = null;
		try {
			writer = response.getWriter();
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		String aodata = RequestUtils.getValue(request, "aodata").replaceAll("&quot;", "\"");
		String stat_date = RequestUtils.getValue(request, "stat_date");
		
		JSONArray ja = JSONArray.fromObject(aodata);

		String sEcho = null;
		Integer iColumns = null;
		Integer iDisplayStart = null;
		Integer iDisplayLength = null;
		List<String> mDataProp = new ArrayList<String>(); // 存放列名
		for (int i = 0; i < ja.size(); i++) {
			if (ja.getJSONObject(i).getString("name").equals("sEcho"))
				sEcho = ja.getJSONObject(i).getString("value");
			else if (ja.getJSONObject(i).getString("name").equals("iColumns"))
				iColumns = Integer.valueOf(ja.getJSONObject(i).getString("value"));
			else if (ja.getJSONObject(i).getString("name").equals("iDisplayStart"))
				iDisplayStart = Integer.valueOf(ja.getJSONObject(i).getString("value"));
			else if (ja.getJSONObject(i).getString("name").equals("iDisplayLength"))
				iDisplayLength = Integer.valueOf(ja.getJSONObject(i).getString("value"));
			else if (iColumns != null) {
				for (int j = 0; j < iColumns; j++)
					if (ja.getJSONObject(i).getString("name").equals("mDataProp_" + j))
						mDataProp.add(ja.getJSONObject(i).getString("value"));
			}
		}
		List<String> params = new ArrayList<String>();
		String sql = "select b.* from ("
						+ "select a.*,rownum rn from ("
							+ "select * from test a where 1=1 ";
		if (!stat_date.equals("")) {
			sql += " and a.stat_date = ?";
			params.add(stat_date);
		}
		sql += " order by a.sort_id)a)b " + " where b.rn between " + iDisplayStart + " and "
				+ (iDisplayStart + iDisplayLength);
		logger.info(sql);
		List<Map<String, Object>> list = db.queryForList(sql, params);
		sql = "select count(1) from test where 1=1 ";
		if (!stat_date.equals("")) {
			sql += " and stat_date = ? ";
		}
		int iTotalRecords = db.queryForInt(sql,new Object[] {stat_date});
		
		JSONObject json = new JSONObject();
		json.put("sEcho", sEcho);
		json.put("iTotalRecords", iTotalRecords);
		json.put("iTotalDisplayRecords", iTotalRecords);
		json.put("aaData", list);
		
		writer.print(json);
		writer.close();

	}

 

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
jquery.datatable是一款常用的前端表格插件,它支持前端后端分页两种方式。在后端分页的情况下,数据请求和处理都在服务器端完成,前端只需要展示和呈现数据。 在使用jquery.datatable进行后端分页时,我们需要进行以下步骤: 1.准备后端接口:需要在服务器端提供一个接口来处理数据请求。这个接口需要接受一些参数,例如当前页码、每页显示数量等。接口会根据这些参数查询数据库,并返回相应的数据结果。 2.前端配置datatable插件:在前端页面中,需要引入jquery.datatable的相应脚本文件,并配置datatable的参数。其中,重要的参数包括ajax配置项,用于指定后端接口的URL,以及服务器端接口需要的参数。 3.发送数据请求:当用户操作表格进行翻页或者其他操作时,jquery.datatable会根据配置的ajax参数自动发送数据请求到后端接口。请求参数中包含当前页码、每页显示数量等信息。 4.服务器处理请求:后端接口接收到数据请求后,根据请求参数进行相应的查询和处理操作。可以使用数据库查询语言等方式查询数据库,并返回结果给前端。 5.前端展示数据:jquery.datatable会自动根据后端返回的数据结果,生成对应的表格展示。同时,它还提供了丰富的功能和样式配置选项,使得表格的展示更加灵活和美观。 总结来说,使用jquery.datatable进行后端分页需要准备后端接口,配置前端datatable,并进行数据请求和处理。这样就能够实现在前端页面展示由后端数据查询而来的分页表格。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值