这一节,我们来实现一下用户列表搜索,最终的效果如下:

这边我们要使用easyUI给我们提供的datagrid组件。

HTML结构如下

<!-- 数据列表 -->
<table id="grid0" class="easyui-datagrid" title="用户列表" style="width:980px;height:550px"
data-options="pagination:true,pageSize:10,rownumbers:true,fitColumns:true,
singleSelect:false,collapsible:false,url:'getUsers.do'">
<thead>
<tr>
<th data-options="field:'ck',checkbox:true"></th>
<th data-options="field:'username',width:80">用户名</th>
<th data-options="field:'password',width:100">密码</th>
<th data-options="field:'name',width:120">姓名</th>
<th data-options="field:'sex',width:120" >性别</th>
</tr>
</thead>
</table>

注意,姓名和性别的field值已经变更,和数据库保持一致,这一点和之前的代码是不一样的。至于datagrid的具体用法,因为本系列课程不是专门讲前端框架EasyUI,所以我也就不多阐述了。感兴趣的童鞋可以去参考EasyUI的官方文档。

我们这边看到,在 data-options 中设置了 urlgetUsers.do 。这个代表在刷新页面的时候,就会自动去寻找对应的Controller,然后加载数据。

如图,我们还设置了分页,每页条数为10。

现在我们来看一下控制器部分:

    @RequestMapping("/getUsers")
@ResponseBody
public Map<String,Object> getUsers(HttpServletRequest request , HttpServletResponse response,Student student){
System.out.println("开始搜索用户..."); int page = Integer.parseInt(request.getParameter("page")); //第几页
int rows = Integer.parseInt(request.getParameter("rows")); //每页多少行 System.out.println(student); Map<String,Object> pageBean = userService.getUsers(student,page,rows); return pageBean;
}

注意,我们在参数列表中加了一个Student:

为什么要添加这个参数呢,那是因为我们最终会通过form表单输入用户名和姓名进行一个模糊查询,所以要在controller层做一个数据绑定。

再看这两个东西,因为datagrid已经设置了分页,所以加载数据的时候就会默认传过来这两个参数,它会自己告诉controller本次请求要查询的是第几页,每页多少条数据?



接下来,我们调用service层的方法,因为是分页查询,所以我们不仅仅要传入需要查询的条件,还要传入分页参数。

最终,我们走到了dao层的方法:

	@Override
public Map<String, Object> getUsers(Student student, int page, int rows) {
String sql = "select * from t_student where 1=1 ";
List args = new ArrayList(); if(student.getId() != 0){
sql += " and id = ?";
args.add(student.getId());
} if(student.getUsername() != null && !"".equals(student.getUsername())){
sql += " and username = ?";
args.add(student.getUsername());
} if(student.getName() != null && !"".equals(student.getName())){
sql += " and name = ?";
args.add(student.getName());
} SimpleDao dao = new SimpleDao();
Map<String, Object> pageBean = dao.queryForPage(sql, page, rows, args.toArray()); return pageBean;
}

相信只要你有一定的java基础和jdbc基础,就一定能看懂这个方法做了些什么?没错,我们挨个判断查询条件,如果有传过来,就拼接到sql语句中去。最后,用queryForPage方法去查询一个分页对象过来。

现在,我们来测试一下,刷新index.html。

可以看到,数据成功的载入了我们的datagrid

接下来,我们给搜索按钮添加点击事件,达到条件查询的目的:

//搜索用户
function searchUser(){
var username = $('#username_search').val(); //用户名
var name = $('#nickname_search').val(); //姓名 $("#grid0").datagrid('load',{
username : username,
name : name
}); }

效果(截图不清晰,请下载后观看):

那如果是模糊查询的话,又该如何实现呢?这个就作为一个小小的作业留给大家,在下一讲我们来揭开答案!

我要下载源码

您的支持是我写作的最大动力:

【Java框架型项目从入门到装逼】第十四节 查询用户列表展现到页面的更多相关文章

  1. 【Java框架型项目从入门到装逼】第四节 - 编写第一个Servlet程序

    在开始这一节之前呢,我们还需要把Tomcat配置到Eclipse中,配置的方式很简单,打开Eclipse,Window,Preferences,进入到这个页面: 将Tomcat的安装目录配置到Ecli ...

  2. 【Java框架型项目从入门到装逼】第七节 - 学生管理系统项目搭建

    本次的教程是打算用Spring,SpringMVC以及传统的jdbc技术来制作一个简单的增删改查项目,对用户信息进行增删改查,就这么简单. 1.新建项目 首先,打开eclipse,新建一个web项目. ...

  3. 【Java框架型项目从入门到装逼】第五节 - 在Servlet中接收和返回数据

    在上一节的程序中,我们可以看到HttpServletRequest, HttpServletResponse这两个对象.可以说,这是JavaWeb中至关重要的两个对象.接下来,我们来做一个简短的说明: ...

  4. 【Java框架型项目从入门到装逼】第六节 - 用ajax请求后台数据

    这一节我们来说一下如何用ajax提交请求? 我们先不讲ajax的原理,还是先以实战为主,看一下这个东西到底怎么用的? form表单: <!-- 采用post表单提交 --> <for ...

  5. 【Java框架型项目从入门到装逼】第十一节 用户新增之把数据传递到后台

    让我们继续来做"主线任务",这一节,我们来做具体的用户新增功能.首先,为了简单起见,我把主页面改了一些,改的是列表那一块.删去了一些字段,和数据库表对应一致: 现在,我们要实现一个 ...

  6. 【Java框架型项目从入门到装逼】第九节 - 数据库建表和CRUD操作

    1.新建学生表 这节课我们来把和数据库以及jdbc相关的内容完成,首先,进行数据库建表.数据库呢,我们采用MySQL数据库,我们可以通过navcat之类的管理工具来轻松建表. 首先,我们得建一个数据库 ...

  7. 【Java框架型项目从入门到装逼】第八节 - 用EasyUI绘制主界面

    1.引入资源包 在上一节中,我们把基本的框架都搭好了,用了Spring,SPringMVC.这一节,我们先来画页面,前端框架采用EasyUI来实现. easyui是一种基于jQuery的用户界面插件集 ...

  8. 【Java框架型项目从入门到装逼】第一节 - Spring框架 IOC的丧心病狂解说

    大家好,好久不见,今天我们来一起学习一下关于Spring框架的IOC技术. 控制反转--Spring通过一种称作控制反转(IoC)的技术促进了松耦合.当应用了IoC,一个对象依赖的其它对象会通过被动的 ...

  9. 【Java框架型项目从入门到装逼】第十二节 项目分层

    这一节我们开始对项目进行分层,一般来说,一个web项目的层次结构如下图所示: controller层为我们的控制层,用来接收用户的请求,比如新增一个学生的信息,新增的请求最先就是走到这一层.contr ...

随机推荐

  1. 3.If statements

    if 语句   电脑程序不只是执行命令.时常会需要做出选择.例如基于一个条件的选择.Python有这样几种条件运算:   >   greater than <   smaller than ...

  2. 《SpringMVC从入门到放肆》一、概述

    一.SpringMVC概述 View Service Dao DB Spring MVC interface interface Mysql impls impls SpringMVC也叫Spring ...

  3. nautilus出现一闪而过现象

    linux相关问题: 1.这几天在使用乌班图时,出现文件夹打开一闪而过现象,于是我试着使用命令行来启动: sudo nautilus 出现下面这一堆错误(error_info): (nautilus: ...

  4. TCP/IP和UDP之间的区别(转载)

    在分析两者之间的区别之前,我们先搞清楚这两者的关系, TCP/IP协议簇  是一种网络控制协议,简单点说就是一种网络协议,我们网络中的计算机就是通过这套协议簇来进行数据通信的.这套协议簇里面包含了很多 ...

  5. Java与算法之(9) - 直接插入排序

    直接插入排序是最简单的排序算法,也比较符合人的思维习惯.想像一下玩扑克牌抓牌的过程.第一张抓到5,放在手里:第二张抓到3,习惯性的会把它放在5的前面:第三张抓到7,放在5的后面:第四张抓到4,那么我们 ...

  6. 【JavaScript数组】

    1.什么是数组--Array 数组就是一组数据的集合 其表现形式就是内存中的一段连续的内存地址 数组名称其实就是连续内存地址的首地址 2.关于js中的数组特点 数组定义时无需指定数据类型 数组定义时可 ...

  7. 学习笔记-echarts点击数据添加跳转链接

    原链接:http://echarts.baidu.com/demo.html#pie-rich-text 这个一段官方提供的实例. var weatherIcons = { 'Sunny': './d ...

  8. 【WC2013】糖果公园

    Candyland 有一座糖果公园,公园里不仅有美丽的风景.好玩的游乐项目,还有许多免费糖果的发放点,这引来了许多贪吃的小朋友来糖果公园玩. 糖果公园的结构十分奇特,它由 nn 个游览点构成,每个游览 ...

  9. 【Java学习笔记之八】JavaBean中布尔类型使用注意事项

    JavaBean是一个标准,遵循标准的Bean是一个带有属性和getters/setters方法的Java类. JavaBean的定义很简单,但是还有有一些地方需要注意,例如Bean中含有boolea ...

  10. [bzoj1316] 树上的询问

    裸的点分治.. 及时把已经确定的询问清掉就能快不少.时间复杂度O(nlogn*p) #include<cstdio> #include<iostream> #include&l ...