【SSH网上商城项目实战08】查询和删除商品类别功能的实现

上一节我们完成了使用DataGrid显示所有商品信息,这节我们开始添加几个功能:添加、更新、删除和查询。首先我们实现下前台的显示,然后再做后台获取数据。

1. 添加、更新、删除和查询功能的前台实现

DataGrid控件里有个toolbar属性,是添加工具栏的,我们可以在toolbar属性中添加这些按钮来实现相应的功能。先看一下官方文档对toolbar的定义:

我们使用数组的方式定义工具栏,在query.jsp页面中新添加如下代码:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
	<%@ include file="/public/head.jspf" %>
	<style type="text/css">
		body {
			margin: 1px;
		}
                .searchbox {
                        margin: -3;
                }
	</style>
	<script type="text/javascript">
		$(function(){
			$('#dg').datagrid({
			    //url地址改为请求categoryAction
			    url:'category_queryJoinAccount.action',

			    singleSelect:false, //如果为真,只允许单行显示,全选功能失效
			    //设置分页
			    pagination:true,
			    //设置每页显示的记录数,默认是10个
			    pageSize:5,
			    //设置可选的每页记录数,供用户选择,默认是10,20,30,40...
			    pageList:[5,10,15,20],
			    idField:'id',//指定id为标识字段,在删除,更新的时候有用,如果配置此字段,在翻页时,换页不会影响选中的项

                     /*********************添加的代码***********************/
			    toolbar: [{
				    iconCls: 'icon-add',
				    text:'添加类别',
				    handler: function(){
					    alert('--加添类别--');
				    }
			    },'-',{
				    iconCls: 'icon-edit',
				    text:'更新类别',
				    handler: function(){
					    alert('--更新类别--');
				    }
			    },'-',{
				    iconCls: 'icon-remove',
				    text:'删除类别',
				    handler: function(){
					    //判断是否有选中行记录,使用getSelections获取选中的所有行
					    var rows = $("#dg").datagrid("getSelections");
					    //返回被选中的行,如果没有任何行被选中,则返回空数组
					    if(rows.length == 0) {
						    //弹出提示信息
						    $.messager.show({ //语法类似于java中的静态方法,直接对象调用
							    title:'错误提示',
							    msg:'至少要选择一条记录',
							    timeout:2000,
							    showType:'slide',
						    });
					    } else {
						    //提示是否确认删除,如果确认则执行删除的逻辑
						    $.messager.confirm('删除的确认对话框', '您确定要删除此项吗?', function(r){
							    if (r){
								// 退出操作;
							        alert("--删除操作--")
 							    }
 						    });
					    }
				    }
			     },'-',{ //查询按钮不是LinkButton,它有语法,但是也支持解析HTML标签
				     text:"<input id='ss' name='serach' />"
			     }],

			    //把普通的文本框转化为查询搜索文本框
			    $('#ss').searchbox({
				    //触发查询事件
				    searcher:function(value,name){ //value表示输入的值
                                           //查询操作
				    },
				    prompt:'请输入搜索关键字' //默认的显示
			    });
               /*********************************************************************/

		});
	</script>
  </head>

  <body>
  	<table id="dg"></table>
  </body>
</html>

这样我们就搭好了添加、更新、删除和查询的前台框架了,现在可以在前台显示了,后台没有数据过来,只是弹出个提示框,不过显示功能已经完成,看一下效果:

接下来我们逐个来完成相应的功能。

2. DataGrid类别查询的实现

查询的实现是最简单的,在搜素框中输入关键字,然后将关键字作为参数传给action,然后Service从数据库中拿出数据,打包成json格式传到前台来显示即可,这个过程跟前面显示所有商品信息是一样的,我们只需要在上面jsp中添加搜索部分的代码即可,其他不用改变,添加的代码如下:

//把普通的文本框转化为查询搜索文本框
$('#ss').searchbox({
	//触发查询事件
	searcher:function(value,name){ //value表示输入的值
		//alert(value + "," + name)
		//获取当前查询的关键字,通过DataGrid加载相应的信息,使用load加载和显示第一页的所有行。
		//如果指定了参数,它将取代'queryParams'属性。通常可以通过传递一些参数执行一次查询,通过调用这个方法会向上面url指定的action去发送请求,从服务器加载新数据。
		$('#dg').datagrid('load',{
			type: value
		});

	},
	prompt:'请输入搜索关键字'
}); 

load方法可以加载显示第一页的所有行,它有个参数,如果指定了,就会去带上么的queryParams,否则默认传递上面的queryParams指定的参数,我们在这里将type设置成value的值,即用户输入的查询关键字,然后传到action,后台根据用户输入的value在数据库中查找,并返回给前台。执行结果如下:

这样我便完成了搜索的功能了,比较简单。

3. DataGrid类别删除的实现

现在我们来实现删除功能,从上面的jsp中可以看出,删除前判断用户有没有选中某条记录,如果没有则给用户一个提示,如果有选中,则弹出窗口让用户确认,如果为真,则执行删除功能。有个细节要注意下,如果想要一次性删除多条记录,那么上面的singleSelect属性要设置成false。

首先,我们把上面query.jsp中删除部分的代码补充完,见下面:

{
	iconCls: 'icon-remove',
	text:'删除类别',
	handler: function(){
		//判断是否有选中行记录,使用getSelections获取选中的所有行
		var rows = $("#dg").datagrid("getSelections");
		//返回被选中的行,如果没有任何行被选中,则返回空数组
		if(rows.length == 0) {
			//弹出提示信息
			$.messager.show({ //语法类似于java中的静态方法,直接对象调用
				title:'错误提示',
				msg:'至少要选择一条记录',
				timeout:2000,
				showType:'slide',
			});
		} else {
			//提示是否确认删除,如果确认则执行删除的逻辑
			$.messager.confirm('删除的确认对话框', '您确定要删除此项吗?', function(r){
				if (r){
				    //1. 从获取的记录中获取相应的的id,拼接id的值,然后发送后台1,2,3,4
				    var ids = "";
				    for(var i = 0; i < rows.length; i ++) {
				    	ids += rows[i].id + ",";
				    }
				    ids = ids.substr(0, ids.lastIndexOf(","));
				    //2. 发送ajax请求
				    $.post("category_deleteByIds.action",{ids:ids},function(result){
				    	if(result == "true") {
                                                //将刚刚选中的记录删除,要不然会影响后面更新的操作
                                                $("#dg").datagrid("uncheckAll");
				    		//刷新当前页,查询的时候我们用的是load,刷新第一页,reload是刷新当前页
				    		$("#dg").datagrid("reload");//不带参数默认为上面的queryParams
				    	} else {
				    		$.messager.show({
								title:'删除异常',
								msg:'删除失败,请检查操作',
								timeout:2000,
								showType:'slide',
							});
				    	}
				    },"text");
				}
			});
		}
	}
}

如果用户选择删除,首先会弹出一个对话框,当用户确定要删除后,我们首先要获取用户所勾选的商品的id,将这些id拼接成一个字符串,然后向后台发送ajax请求,$.post中的第一个参数是发送到那个action,第二个参数是发送的参数,第三个参数是回调函数,即删除成功后执行该函数里面的方法,该函数的参数result是从后台传过来的,第四个参数可有可无,是返回数据的类型。我们重点看看$.post中的内容,当后台返回一个"true"表示删除成功了,那么我们调用DataGrid里面的reload方法重新刷新页面,reload和前面查询时用的load是一样的,不同的地方在于reload刷新后停留在当前页面,而load则显示第一页。

好了,前台页面部分写好了,接下来完成后台的相应方法,首先在categoryService中添加deleteByIds方法,并在其实现类categoryServceImpl中实现该方法:

//categoryService接口
public interface CategoryService extends BaseService<Category> {
	//查询类别信息,级联管理员
	public List<Category> queryJoinAccount(String type, int page, int size); //使用类别的名称查询
	//根据关键字查询总记录数
	public Long getCount(String type);
	//根据ids删除多条记录
	public void deleteByIds(String ids);
}

//categoryServiceImpl实现类
@SuppressWarnings("unchecked")
@Service("categoryService")
public class CategoryServiceImpl extends BaseServiceImpl<Category> implements CategoryService {

    //其他方法省略不写了……可以参照前面的相应章节内容

    @Override
    public void deleteByIds(String ids) {
        String hql = "delete from Category c where c.id in (" + ids + ")";
        getSession().createQuery(hql).executeUpdate();
    }
}

写好了Service部分,接下来开始写Action部分了。因为我们要获取前台传进来的ids数据,所以在action中得有一个实现了get和set方法的变量来接收这个数据,另外,我们要将结果传给前台,前面章节中我们做级联查询的时候,使用的方法是struts把查询的结果数据打包成json格式传给前台,所以需要一个Map,然后将通过配置文件中的配置,将Map转换成json格式。这里我们传到前台的数据比较简单,入股删除成功我们传一个"true"即可,所以不用打包成json格式,我们通过流的方法去传送,道理和前面的一样,首相我们得有一个流的对象去保存这个"true"的字节,然后通过配置,将这个对象通过流传到前台。这两个对象我们还是写在BaseAction中,如下:

@Controller("baseAction")
@Scope("prototype")
public class BaseAction<T> extends ActionSupport implements RequestAware,SessionAware,ApplicationAware,ModelDriven<T> {

	//获取要删除的ids,要有get和set方法
	//流是用来想前台返回数据的,这个数据是让struts获取的,然后通过流的形式传到前台,所以实现get方法即可
	protected String ids;
	protected InputStream inputStream;

        //下面省略……
}

对应的CategoryAction中的方法如下:

@Controller("categoryAction")
@Scope("prototype")
public class CategoryAction extends BaseAction<Category> {

	public String queryJoinAccount() {
                //略……
	}

	public String deleteByIds() {
		System.out.println(ids);
		categoryService.deleteByIds(ids);
		//如果删除成功就会往下执行,我们将"true"以流的形式传给前台
		inputStream = new ByteArrayInputStream("true".getBytes()); //将"true"的字节存到流inputStream中
		return "stream";
	}
}

接下来看struts.xml中相应的配置:

<struts>

	<constant name="struts.devMode" value="true" />

	<package name="shop" extends="json-default"><!-- jason-default继承了struts-default -->

		<global-results>
			<result name="aindex">/WEB-INF/main/aindex.jsp</result>
		</global-results>

		<!-- class对应的是Spring中配置该Action的id值,因为要交给Spring管理 -->
		<action name="category_*" class="categoryAction" method="{1}">
			<result name="jsonMap" type="json">
				<!-- 略 -->
			</result>
			<result name="stream" type="stream"> <!-- 以stream的形式,type为stream -->
				<param name="inputName">inputStream</param> <!-- imputStream中有要传的数据 -->
			 </result>
		</action>

		<action name="account_*" class="accountAction" method="{1}">
			<result name="index">/index.jsp</result>
		</action>

		<!-- 用来完成系统 请求转发的action,所有的请求都交给execute-->
		<action name="send_*_*" class="sendAction">
			<result name="send">/WEB-INF/{1}/{2}.jsp</result>
		</action>
	</package>

</struts>

这样我们就做好了删除的操作了,看一下效果:

测试成功,我们也可以一次性选择多项去删除,至此,删除功能做完了。

(注:到最后我会提供整个项目的源码下载!欢迎大家收藏或关注)

相关阅读:http://blog.csdn.net/column/details/str2hiberspring.html

_____________________________________________________________________________________________________________________________________________________

-----乐于分享,共同进步!

-----更多文章请看:http://blog.csdn.net/eson_15

时间: 2024-10-12 06:59:23

【SSH网上商城项目实战08】查询和删除商品类别功能的实现的相关文章

【SSH网上商城项目实战18】过滤器实现购物登录功能的判断

上一节我们做完了购物车的基本操作,但是有个问题是:当用户点击结算时,我们应该做一个登录的判断,判断用户有没有登录,没有登录的话,得首先让用户登录.这就用到了过滤器的技术了,过滤器是专门拦截页面请求的,它与拦截器的原理差不多,拦截器是专门拦截Action请求的,所以各有所用,如果直接是页面的跳转,不经过Action的话,我们只要写一个拦截器即可,如果需要跳转到一个Action处理,那么我们就得写一个拦截器. 1. 登录跳转的原理 先说一下实现原理:写一个过滤器,在web.xml中配置一下需要拦截的

【SSH网上商城项目实战11】查询和删除商品功能的实现

在第8节我们完成了查询和删除商品类别的功能,那么现在实现查询和删除商品的功能就很好做了,原理和第8节一模一样,只是修改一些参数,比如请求不同的action等.由于查询和删除商品不需要弹出新的UI窗口,所以我们只要完成完成query.jsp中相应的部分以及相应的后台即可. 1. 查询商品功能的实现 查询功能主要在查询框中实现,从上一节可知,查询框用的是一个text:"<input id='ss' name='serach' />",我们通过把普通的文本框转化为查询搜索文本框来

【SSH网上商城项目实战09】添加和更新商品类别功能的实现

上一节我们做完了查询和删除商品的功能,这一节我们做一下添加和更新商品的功能. 1. 添加商品类别 1.1 添加类别的UI设计 我们先说一下思路:首先当用户点击"添加商品"时,我们应该弹出一个"添加商品"的UI窗口(注意这里不是跳转到新的jsp,EasyUI只有一个页面),弹出这个"添加商品"的窗口后,应该锁住它父类的所有窗口(即点击其他地方无效,只能操作添加商品的窗口),等用户填好了信息后,在新弹出来的窗口上点击"添加"后,将

【SSH网上商城项目实战27】域名空间的申请和项目的部署及发布

前面陆陆续续的完成了网上商城的一些基本功能,虽然还有很多地方有待完善,但是不影响项目的部署和发布,我们可以先来玩一把,这一节主要介绍下域名空间的申请以及项目的部署和发布流程. 1. 域名空间的申请 作为一个伟大的屌丝,肯定没钱买域名空间,很自然的想到去申请个免费的,现在免费的域名空间也很多,我在福佳jsp技术网上申请了一个试用期是15天的,大家也可以去申请个玩玩,反正作为学习,这已经足够了,当然,如果要长期的肯定要付费的.注册过程我截几个图,如下: 然后下一步,最后开通如下: 建议把上面这些信息

【SSH网上商城项目实战16】Hibernate的二级缓存处理首页的热门显示

网上商城首页都有热门商品,那么这些商品的点击率是很高的,当用户点击某个热门商品后需要进入商品的详细信息页面,就像淘宝里面那样.那么每次点击都要去后台查询一下该商品的详细信息,就会发送相应的sql语句,每次刷新一下详细页面也会发sql语句,这样的话,性能肯定会受到很大的影响.那么使用Hibernate的二级缓存就可以解决这个问题. 有些人可能会想,我们可以使用重定向,这样的话,在用户第一次访问的时候把信息查出来放到session中,以后每次用户刷新就可以去session中拿了,这样就不用去数据库中

【SSH网上商城项目实战21】从Demo中看易宝支付的流程

这一节我们先写一个简单点的Demo来测试易宝支付的流程,熟悉这个流程后,再做实际的开发,因为是一个Demo,所以我没有考虑一些设计模式的东西,就是直接实现支付功能.实现支付功能需要易宝给我们提供的API.那么问题来了,使用第三方支付平台最主要的一件事就是获取该平台的API,我们首先得获取他们的API以及开发文档,然后才可以做进一步的开发. 1. 获取易宝的API 获取API的第一步,要在易宝上注册一个账号,这个账号是商家的账号,后面买家付款后,会将钱款存入该账号中,然后商家自己提取到银行卡,易宝

【SSH网上商城项目实战14】商城首页UI的设计

前面我们利用EasyUI和SSH搭建好了后台的基本框架,做好了后台的基本功能,包括对商品类别的管理和商品的管理等,这一节我们开始搭建前台页面. 做首页的思路:假设现在商品的业务逻辑都有了,首先我们需要创建一个监听器,在项目启动时将首页的数据查询出来放到application里,即在监听器里调用后台商品业务逻辑的方法. 1.  首页商品显示逻辑 在首页,我们只显示商品热点类别中的前几个商品,比如热点类别有儿童休闲类,女性休闲类,男性休闲类,那我们会有三个板块来显示不同的商品类,每个类别里再显示几个

【SSH网上商城项目实战10】商品类基本模块的搭建

前面我们完成了与商品类别相关的业务逻辑,接下来我们开始做具体商品部分. 1. 数据库建表并映射Model 首先我们在数据库中新建一张表,然后使用逆向工程将表映射成Model类,表如下: /*=============================*/ /* Table: 商品表结构 */ /*=============================*/ create table product ( /* 商品编号,自动增长 */ id int primary key not null aut

【SSH网上商城项目实战25】使用java email给用户发送邮件

当用户购买完商品后,我们应该向用户发送一封邮件,告诉他订单已生成之类的信息,邮箱地址是从用户的基本信息中获取,好了,首先我们来看一下Java中发送邮件的方法. 1. java中发送email的方法     在完善这个项目之前,先来回顾一下java中是如何发送邮件的,首先肯定需要发送邮件的jar包:mail.jar,导入到lib目录下,好了,下面我们先写一个普通的java程序来回顾一下java email的知识点: public class SendEmailDemo { public stati