项目用到ajax技术的查询,查询结果很多时候要分页展示。这两天摸索了一下,在这里做一总结,方便自己随时查看,

也方便后人参考。

这里的顺序遵从从前台页面到后台控制器,业务层,Dao层,Mapper

下面先讲页面,页面js代码如下:

  1. <span style="font-size:14px;">/* 全局变量 */
  2. var userCount;//符合查找条件的用户总页数,分页参考
  3. var pageIndex = 0;//当前页,默认为0
  4. var pageSize = 8;//每页显示个数为8
  5. //按条件查找用户
  6. function searchUser(index,size) {
  7. var findTerm = $("#serchTerm").val();
  8. var provinceId = $('#province').val();
  9. var cityId = $('#city').val();
  10. $.ajax({
  11. type : "POST",
  12. url : "user/findContactsAjax",
  13. cache : false,
  14. data : {
  15. provinceId : provinceId,
  16. cityId : cityId,
  17. pageIndex:index,
  18. pageSize:size
  19. },
  20. async : true,
  21. error : function() {
  22. alert("网络异常!");
  23. },
  24. success : function(data) {
  25. <span style="white-space:pre">    </span>userCount=Math.ceil(data[0].userCount/8);<span style="white-space:pre">                                                  </span>var page='<div id="userPage" align="center" ><font size="2">共'
  26. +userCount+'页</font> <font size="2">第'
  27. +(pageIndex+1)+'页</font> <a href="javascript:void" onclick="GoToFirstPage()" id="aFirstPage" >首页</a> '
  28. +'<a href="javascript:void" onclick="GoToPrePage()" id="aPrePage"  >上一页</a>  '
  29. +'<a href="javascript:void" onclick="GoToNextPage()" id="aNextPage" >下一页</a>  '
  30. +'<a href="javascript:void" onclick="GoToEndPage()" id="aEndPage" >尾页</a>  ';
  31. page+='</div>';
  32. $("#serchResult").append(page);
  33. document.getElementById("dltitle").innerHTML = "查找结果如下";
  34. }
  35. }
  36. });
  37. }
  38. //首页
  39. function GoToFirstPage() {
  40. pageIndex = 0;
  41. searchUser( pageIndex, pageSize);
  42. }
  43. //前一页
  44. function GoToPrePage() {
  45. pageIndex -= 1;
  46. pageIndex = pageIndex >= 0 ? pageIndex : 0;
  47. searchUser( pageIndex, pageSize);
  48. }
  49. //后一页
  50. function GoToNextPage() {
  51. if (pageIndex + 1 < userCount) {
  52. pageIndex += 1;
  53. }
  54. searchUser( pageIndex, pageSize);
  55. }
  56. //尾页
  57. function GoToEndPage() {
  58. pageIndex = userCount - 1;
  59. searchUser( pageIndex, pageSize);
  60. }</span>

控制层代码如下:

  1. @RequestMapping("findContactsAjax")
  2. public @ResponseBody
  3. Map<String, Object> findContactAjax(String provinceId,String cityId,String pageIndex,String pageSize) {
  4. List<User> listUsers = userDao.selectUserByProvinceAndCity(provinceId, cityId,pageIndex,pageSize)
  5. }
  6. map.put("user", listUsers);
  7. return map;
  8. }

Dao层:

  1. List<User> selectUserByProvinceAndCity(@Param("provinceId") Integer provinceId, @Param("cityId") Integer cityId,
  2. @Param("pageIndex") Integer pageIndex,@Param("pageSize") Integer pageSize);

mapper文件:

  1. <select id="selectUserByProvinceAndCity" resultMap="BaseResultMap">
  2. SELECT *,
  3. (SELECT  COUNT(*) FROM user_user_t
  4. province_id=#{provinceId}
  5. AND
  6. city_id=#{cityId}) AS userCount
  7. FROM user_user_t
  8. province_id=#{provinceId}
  9. AND
  10. city_id=#{cityId}
  11. LIMIT #{pageIndex},#{pageSize}
  12. </select>

User实体

    1. public class User {
    2. private Integer userId;
    3. private String userName;
    4. private Integer provinceId;
    5. private Integer cityId;
    6. private Integer userCount;//满足查询条件的用户数目,作为分页的依据
    7. }
  1. 《转:http://blog.csdn.net/gisredevelopment/article/details/39084945》

springMVC+ajax分页查询的更多相关文章

  1. Mybatis+SpringMVC实现分页查询(附源码)

    Maven+Mybatis+Spring+SpringMVC实现分页查询(附源码) 一.项目搭建 关于项目搭建,小宝鸽以前写过一篇Spirng+SpringMVC+Maven+Mybatis+MySQ ...

  2. ajax分页查询

    (1)先写个显示数据的页面,分页查询需要那几个部分呢? 1.首先是查询的文本框输入,还有查询按钮,那么就开始写代码吧 1 2 3 4 <div> <input type=" ...

  3. Maven+Mybatis+Spring+SpringMVC实现分页查询

    转载:http://www.cnblogs.com/zhangtan/p/5846955.html 一.项目搭建 关于项目搭建,小宝鸽以前写过一篇Spirng+SpringMVC+Maven+Myba ...

  4. ajax分页查询信息的通用方法

    1.页面准备分页的表格与分页div 同时需要在查询条件表单中准备隐藏当前页与页大小的文本框 <div class="container-fluid"> <div ...

  5. Maven+Mybatis+Spring+SpringMVC实现分页查询(附源代码)

    以下小宝鸽将分享一篇Mybatis分页功能的博文,以下将给出具体的步骤.跟着博主的节奏肯定能实现.另外最后还会附上整个project的源代码.假设是没有使用过maven的猿友可自行下载相关的jar包就 ...

  6. 使用ajax分页查询

    controller: /** * 查询所有用户/查找指定用户 * 分页+搜索 * */@RequestMapping("/findClientBySize")@ResponseB ...

  7. kkpager 实现ajax分页查询

    前台分页数据,适合数据少量的时候,因为分页的数据是从后台获取的,大数据的话不建议使用 现看前台代码: @{ Layout = null; } <!DOCTYPE html> <htm ...

  8. Ajax写分页查询(实现不刷新页面)

    获取数据库中大量的信息显示在页面上,必然要使用到分页查询: 若不使用Ajax,而是用其他的方法,肯定是要刷新页面的,用户体检很不好, 所以最好使用Ajax的方法写分页查询: 1.先来找一张数据很多的表 ...

  9. ThinkPHP 整合Bootstrap Ajax分页

    ThinkPHP Ajax分页代码 publicfunction index() { $where=array(); $name = I('name'); if(!empty($name)){ $wh ...

随机推荐

  1. Python基础(二),Day2

    常用的数据类型 int 整型 float 浮点 bool 布尔 string 字符串 列表的语法和用法 # 创建一个列表 list = [] #一个空列表 list = ['2323123','asd ...

  2. Webform(Repeater控件)

    一.Repeater控件 有五大模板 ItemTemplate :有多少条数据,执行多少遍        AlternatingItemTemplate : 对交替数据项进行格式设置       Se ...

  3. java分派

    变量被声明时的类型叫做变量的静态类型(Static Type) 又叫明显类型(Apparent Type).变量所引用的对象的真实类型又叫做变量的实际类型(Actual Type). 根据对象的类型而 ...

  4. JS控制HTML元素的显示和隐藏

    JS控制HTML元素的显示和隐藏 利用来JS控制页面控件显示和隐藏有两种方法,两种方法分别利用HTML的style中的两个属性,两种方法的不同之处在于控件隐藏后是否还在页面上占空位. 方法一: 1 2 ...

  5. 使用HyperV虚拟机装系统

    新建虚拟机 新建虚拟机 进行相关参数设置 选择系统安装镜像位置,名称及位置 指定代数一般为1代即可 为虚拟机运行分配内存 创建虚拟硬盘或连接已有虚拟硬盘,并分配硬盘空间 核对创建虚拟机相关信息 安装系 ...

  6. [C/C++] VS 2015 C++ 插件

    Visual Studio2015 Community一些必备插件 ReSharper C++ 各种语言版本的代码重构,代码风格,代码修正功能,非常强大,可惜不是免费的,不过好在可以破解呢. Vias ...

  7. [Java] JDK 系统环境变量设置 bat

    @echo off set regpath=HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Environmen ...

  8. ExtJs中xtype与组件类的对应表

    from:http://blog.163.com/jx_dream/blog/static/117056627201223091021410/ 核心提示:我们在使用 ExtJs 创建组件时最容易理解的 ...

  9. iOS仿京东分类菜单之UICollectionView内容

    在上<iOS仿京东分类菜单实例实现>已经实现了大部分主体的功能,本文是针对右边集合列表进行修改扩展,使它达到分组的效果,本文涉及到的主要是UICollectionView的知识内容,左边列 ...

  10. windows下使用tomcat部署网站

    一.配置过程: 1.  配置java环境(之前已装过,跳过此步骤) 2.  下载tomcat (1)找到支持此java版本的tomcat版本: (2)下载与当前系统对应的安装文件 http://tom ...