springMVC+ajax分页查询
项目用到ajax技术的查询,查询结果很多时候要分页展示。这两天摸索了一下,在这里做一总结,方便自己随时查看,
也方便后人参考。
这里的顺序遵从从前台页面到后台控制器,业务层,Dao层,Mapper
下面先讲页面,页面js代码如下:
- <span style="font-size:14px;">/* 全局变量 */
- var userCount;//符合查找条件的用户总页数,分页参考
- var pageIndex = 0;//当前页,默认为0
- var pageSize = 8;//每页显示个数为8
- //按条件查找用户
- function searchUser(index,size) {
- var findTerm = $("#serchTerm").val();
- var provinceId = $('#province').val();
- var cityId = $('#city').val();
- $.ajax({
- type : "POST",
- url : "user/findContactsAjax",
- cache : false,
- data : {
- provinceId : provinceId,
- cityId : cityId,
- pageIndex:index,
- pageSize:size
- },
- async : true,
- error : function() {
- alert("网络异常!");
- },
- success : function(data) {
- <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">共'
- +userCount+'页</font> <font size="2">第'
- +(pageIndex+1)+'页</font> <a href="javascript:void" onclick="GoToFirstPage()" id="aFirstPage" >首页</a> '
- +'<a href="javascript:void" onclick="GoToPrePage()" id="aPrePage" >上一页</a> '
- +'<a href="javascript:void" onclick="GoToNextPage()" id="aNextPage" >下一页</a> '
- +'<a href="javascript:void" onclick="GoToEndPage()" id="aEndPage" >尾页</a> ';
- page+='</div>';
- $("#serchResult").append(page);
- document.getElementById("dltitle").innerHTML = "查找结果如下";
- }
- }
- });
- }
- //首页
- function GoToFirstPage() {
- pageIndex = 0;
- searchUser( pageIndex, pageSize);
- }
- //前一页
- function GoToPrePage() {
- pageIndex -= 1;
- pageIndex = pageIndex >= 0 ? pageIndex : 0;
- searchUser( pageIndex, pageSize);
- }
- //后一页
- function GoToNextPage() {
- if (pageIndex + 1 < userCount) {
- pageIndex += 1;
- }
- searchUser( pageIndex, pageSize);
- }
- //尾页
- function GoToEndPage() {
- pageIndex = userCount - 1;
- searchUser( pageIndex, pageSize);
- }</span>
控制层代码如下:
- @RequestMapping("findContactsAjax")
- public @ResponseBody
- Map<String, Object> findContactAjax(String provinceId,String cityId,String pageIndex,String pageSize) {
- List<User> listUsers = userDao.selectUserByProvinceAndCity(provinceId, cityId,pageIndex,pageSize)
- }
- map.put("user", listUsers);
- return map;
- }
Dao层:
- List<User> selectUserByProvinceAndCity(@Param("provinceId") Integer provinceId, @Param("cityId") Integer cityId,
- @Param("pageIndex") Integer pageIndex,@Param("pageSize") Integer pageSize);
mapper文件:
- <select id="selectUserByProvinceAndCity" resultMap="BaseResultMap">
- SELECT *,
- (SELECT COUNT(*) FROM user_user_t
- province_id=#{provinceId}
- AND
- city_id=#{cityId}) AS userCount
- FROM user_user_t
- province_id=#{provinceId}
- AND
- city_id=#{cityId}
- LIMIT #{pageIndex},#{pageSize}
- </select>
User实体
- public class User {
- private Integer userId;
- private String userName;
- private Integer provinceId;
- private Integer cityId;
- private Integer userCount;//满足查询条件的用户数目,作为分页的依据
- }
- 《转:http://blog.csdn.net/gisredevelopment/article/details/39084945》
springMVC+ajax分页查询的更多相关文章
- Mybatis+SpringMVC实现分页查询(附源码)
Maven+Mybatis+Spring+SpringMVC实现分页查询(附源码) 一.项目搭建 关于项目搭建,小宝鸽以前写过一篇Spirng+SpringMVC+Maven+Mybatis+MySQ ...
- ajax分页查询
(1)先写个显示数据的页面,分页查询需要那几个部分呢? 1.首先是查询的文本框输入,还有查询按钮,那么就开始写代码吧 1 2 3 4 <div> <input type=" ...
- Maven+Mybatis+Spring+SpringMVC实现分页查询
转载:http://www.cnblogs.com/zhangtan/p/5846955.html 一.项目搭建 关于项目搭建,小宝鸽以前写过一篇Spirng+SpringMVC+Maven+Myba ...
- ajax分页查询信息的通用方法
1.页面准备分页的表格与分页div 同时需要在查询条件表单中准备隐藏当前页与页大小的文本框 <div class="container-fluid"> <div ...
- Maven+Mybatis+Spring+SpringMVC实现分页查询(附源代码)
以下小宝鸽将分享一篇Mybatis分页功能的博文,以下将给出具体的步骤.跟着博主的节奏肯定能实现.另外最后还会附上整个project的源代码.假设是没有使用过maven的猿友可自行下载相关的jar包就 ...
- 使用ajax分页查询
controller: /** * 查询所有用户/查找指定用户 * 分页+搜索 * */@RequestMapping("/findClientBySize")@ResponseB ...
- kkpager 实现ajax分页查询
前台分页数据,适合数据少量的时候,因为分页的数据是从后台获取的,大数据的话不建议使用 现看前台代码: @{ Layout = null; } <!DOCTYPE html> <htm ...
- Ajax写分页查询(实现不刷新页面)
获取数据库中大量的信息显示在页面上,必然要使用到分页查询: 若不使用Ajax,而是用其他的方法,肯定是要刷新页面的,用户体检很不好, 所以最好使用Ajax的方法写分页查询: 1.先来找一张数据很多的表 ...
- ThinkPHP 整合Bootstrap Ajax分页
ThinkPHP Ajax分页代码 publicfunction index() { $where=array(); $name = I('name'); if(!empty($name)){ $wh ...
随机推荐
- Visual Studio图片注释image-comments扩展
有一个开源的Visual Studio小工具image-comments,它用于在源代码注释中插入图片,您可以到这儿下载.目前支持Visual Studio 2010/2012 Sta ...
- react与redux学习资料的整理
**重点内容**React学习 1.新手入门可以访问react的官方网站,如果英语不是特别好的同学可以访问中文版的,具体链接http://reactjs.cn/react/index.html 首页有 ...
- 关于DOM操作的性能优化
最著名的有关用js操作dom的观点是:js和dom是独立的小岛,用桥实现两者的联系,但桥很窄,要过路费,所以我们要尽最大可能减少过桥的次数.下面代码演示了用js操作dom的innerHTML,且一下修 ...
- 挖掘机技术哪家强(c++实现)
描述:为了用事实说明挖掘机技术到底哪家强,组织一场挖掘机技能大赛.现请你根据比赛结果统计出技术最强的那个学校. 输入:输入在第1行给出不超过105的正整数N,即参赛人数.随后N行,每行给出一位参赛者的 ...
- 实验三同学评论http://home.cnblogs.com/u/MyDring/
47赖燕菲http://www.cnblogs.com/lyfzero/ :该同学实验整体思路较清晰,希望把完整代码发布出来. 48李小娜http://www.cnblogs.com/dmbs/ :该 ...
- Android项目实战(十五):自定义不可滑动的ListView和GridView
不可滑动的ListView (RecyclweView类似) public class NoScrollListView extends ListView { public NoScrollListV ...
- Caused by: java.lang.UnsupportedOperationException
对Arrays.asList()返回的List进行操作之后报错Caused by: java.lang.UnsupportedOperationException 让我们来看一下Arrays.asLi ...
- Android Service使用拾遗[阿里工程师分享]
Service作为android的四大组件之一常用来帮助我们完成一些需要放在后台处理的任务,通过startService和bindService两种方式被调用.因为Service也是在主线程中运行的, ...
- 可折叠的ToolBar+抽屉菜单NavigationView+浮动按钮FloatButton
使用Material Design风格的ToolBar和抽屉导航 先看个简单的运行效果 主要记录下布局的写法 1 用到的Google Design依赖和V7包依赖 compile 'com.andro ...
- Silverlight项目笔记1:UI控件与布局、MVVM、数据绑定、await/async、Linq查询、WCF RIA Services、序列化、委托与事件
最近从技术支持转到开发岗,做Silverlight部分的开发,用的Prism+MVVM,框架由同事搭好,目前做的主要是功能实现,用到了一些东西,侧重于如何使用,总结如下 1.UI控件与布局 常用的主要 ...