EasyUI 页面分页

Posted 琢磨先生

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了EasyUI 页面分页相关的知识,希望对你有一定的参考价值。

DAO

package com.hanqi.dao;

import java.util.ArrayList;
import java.util.List;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;

import com.hanqi.entity.Region;
import com.hanqi.entity.Student;

public class StudentDAO {


	Configuration  cfg = null;
	ServiceRegistry  sr = null;
	 SessionFactory sf = null;
	 Session  se =null;
	Transaction tr = null;
	
	public StudentDAO()//注册服务
	{
		//1.加载配置文件
				cfg = new Configuration().configure();
				//2.注册服务
				 sr = new  StandardServiceRegistryBuilder()
						.applySettings(cfg.getProperties()).build();
	}
	//初始化
	private void init()
	{
		sf= cfg.buildSessionFactory(sr);
		se = sf.openSession();
		tr = se.beginTransaction();
	}
	//提交和释放
	private void destroy()
	{
		tr.commit();//提交事务
		se.close();
		sf.close();
	}
	
	//获取分页数据集合列表
	public List<Student> getPageList(int page , int rows)
	{
		init();
		 List<Student> rtn = new ArrayList<>(); 
		 rtn = se.createQuery("from Student").setMaxResults(rows)//每页行数
				 .setFirstResult((page-1)*rows).list();//其实页码

		 destroy();
		return rtn;
	}
	
	//获取数据条数
	public int getTotal()
	{
		int rtn= 0;
		init();
		//获取Query对对象,定义集合并实例化
		List<Object> lo = se.createQuery("select count(1) from Student").list();
		
		if(lo != null && lo.size() > 0)
		{
			rtn = Integer.parseInt(lo.get(0).toString());//转换成int并赋值
		}
		
		 destroy();
		
		return rtn;
	}
}

  service

package com.hanqi.service;

import java.util.ArrayList;
import java.util.List;

import com.alibaba.fastjson.JSONArray;
import com.hanqi.dao.StudentDAO;
import com.hanqi.entity.Student;

public class StudentService {
	
	PageJSON<Student> lls = new PageJSON<Student>();
	//查询分页数据
	//返回JSON
	public String getPageJSON(int page, int rows)
	{
		
		
		String rtn = "{total:0,rows:[]}";//空的JSON对象
		
		int total = new StudentDAO().getTotal();
		if(total>0)
		{
			List<Student> ls = new StudentDAO().getPageList(page, rows);
			
			String ls_json = JSONArray.toJSONString(ls);//转成JSON格式
			
			//转义字符,转成JSON读取的格式
			
			rtn =  "{\\"total\\":"+total+",\\"rows\\":"+ls_json+"}" ;

			
		}
		
		return rtn;
	}

}

  Servlet

package com.hanqi.web;

import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.hanqi.service.StudentService;

/**
 * Servlet implementation class StudentServlet
 */
public class StudentServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public StudentServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

	
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		//转码
		request.setCharacterEncoding("UTF-8");
		response.setCharacterEncoding("UTF-8");
		response.setContentType("text/html");
		
		//接受参数
		String spage = request.getParameter("page");//页码
		String srows = request.getParameter("rows");//每页行数
		
		if(spage!= null && srows != null)
		{
			//转型
			int page = Integer.parseInt(spage);
			int rows = Integer.parseInt(srows);
		
			String json = new StudentService().getPageJSON(page, rows);
			response.getWriter().println(json);
		}
		else
		{
			response.getWriter().println("{total:0,rows:[]}");
		}
	}

	/**
	 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		// TODO Auto-generated method stub
		doGet(request, response);
	}

}

  页面

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<!-- 顺序不可以乱 -->
<!-- 1.jQuery的js包 -->
<script type="text/javascript" src="jquery-easyui-1.4.4/jquery.min.js"></script>
<!-- 2.css资源 -->
<link  rel="stylesheet" type="text/css" href="jquery-easyui-1.4.4/themes/default/easyui.css">
<!-- 3. 图标资源 -->
<link  rel="stylesheet" type="text/css" href="jquery-easyui-1.4.4/themes/icon.css">
<!-- 4.easyui的js包 -->
<script type="text/javascript" src="jquery-easyui-1.4.4/jquery.easyui.min.js"></script>
<!-- 5.本地语言 -->
<script type="text/javascript" src="jquery-easyui-1.4.4/locale/easyui-lang-zh_CN.js"></script>
</head>
<body>
<script type="text/javascript">
$(function(){
	
	$("#hh").datagrid({
		
		url:\'StudentServlet\',
	//冻结列
	frozenColumns:[[
	                {field:\'id\',checkbox:true},//复选框
	                {field:\'sno\',title:\'学号\',width:100}  
	                
	                
	                ]],
	              //定义列
	        	    columns:[[    

	        	        {field:\'sname\',title:\'姓名\',width:200,align:\'center\'},    
	        	        {field:\'ssex\',title:\'性别\',width:200,align:\'center\',
	        	        	formatter: function(value,row,index){
	        	        		if(value == \'f\')
	        	        			{
	        	        				return \'男\';
	        	        			}
	        	        		else if(value == \'m\')
	        	        			{
	        	        				return \'女\';
	        	        			}
	        	        		else if(value == \'男\')
        	        			{
        	        				return \'男\';
        	        			}
	        	        		else if(value == \'女\')
        	        			{
        	        				return \'女\';
        	        			}
	        	        		else
	        	        			{
	        	        			return \'哈哈\';
	        	        			}
	        	        		
	        	        	},
	        	        	styler:function(value,row,index){
	        	        		if(value==\'男\')
	        	        			{
	        	        				return \'background-color:#ccccff;color:red;\';

	        	        			}
	        	        		else if(value == \'f\')
	        	        			{
	        	        			 	return \'background-color:#ccccff;color:red;\';
	        	        			}
	        	        	}
	        	        } ,
	        	        
	        	        {field:\'sbirthday\',title:\'生日\',width:200,align:\'right\'},
	        	        {field:\'sclass\',title:\'班级\',width:200,align:\'right\'}
	        	        	
	        	        
	        	        
	        	    ]] ,
	        	    fitColumns:false,       //列自适应宽度,不能和冻结列同时设置为true
	        	    striped:true,           //斑马线
	        	    idField:\'sno\',     //主键列
	        	    rownumbers:true,        //显示行号
	        	    singleSelect:false,      //是否单选
	        	    pagination:true,         //分页栏
	        	    pageList:[8,16,24,32] ,  //每页行数选择列表
	        		pageSize:8   ,            //初始每页行数
	        		remoteSort:false,        //是否服务器端排序,设成false才能客户端排序
	        		//sortName:\'unitcost\',     //定义哪些列可以进行排序。
	        		
	        		toolbar:[
	        		         {
	        		        	 iconCls:\'icon-add\',
	        		        	 text:\'添加\',
	        		        	 handler:function(){
	        		        		 alert(\'添加按钮被点击\')},
	        		         },
	        		         {
	        		        	 iconCls:\'icon-edit\',
	        		        	 text:\'修改\',
	        		        	 handler:function(){
	        		        		 alert(\'修改按钮被点击\')},
	        		         },
	        		         {
	        		        	 iconCls:\'icon-delete\',
	        		        	 text:\'删除\',
	        		        	 handler:function(){
	        		        		 alert(\'删除按钮被点击\')},
	        		         }
	        		         ],
	});
})




</script>
<table id="hh"></table>
</body>
</html>

  

 

以上是关于EasyUI 页面分页的主要内容,如果未能解决你的问题,请参考以下文章

异步分页 EasyUI

springmvc+easyUI的DataGrid分页功能

easyui分页控件不显示怎么回事?

jquery easyui datagrid 分页实现

easyui datagrid页面序号框怎么变宽

pagination分页问题