SSH框架网上商城项目第14战之商城首页UI的设计_java

前面我们利用EasyUI和SSH搭建好了后台的基本框架,做好了后台的基本功能,包括对商品类别的管理和商品的管理等,这一节我们开始搭建前台页面。
做首页的思路:假设现在商品的业务逻辑都有了,首先我们需要创建一个监听器,在项目启动时将首页的数据查询出来放到application里,即在监听器里调用后台商品业务逻辑的方法。

1.  首页商品显示逻辑
在首页,我们只显示商品热点类别中的前几个商品,比如热点类别有儿童休闲类,女性休闲类,男性休闲类,那我们会有三个板块来显示不同的商品类,每个类别里再显示几个具体的商品。如果要实现这样的首页的话,我们需要将哪些数据查询出来呢?首先肯定是热点类别,即在数据库中查询类别是热点的项,然后再从数据库中根据热点类别级联查询该类别的商品,这样我们所要的数据就都有了。下面我们先在后台完成这些查询业务:

//CategoryService接口
public interface CategoryService extends BaseService<Category> {
 //省略其他方法……
 //根据boelen值查询热点或非热点类别
 public List<Category> queryByHot(boolean hot);
} 

@SuppressWarnings("unchecked")
@Service("categoryService")
public class CategoryServiceImpl extends BaseServiceImpl<Category> implements CategoryService { 

 //省略其他方法…… 

 @Override
 public List<Category> queryByHot(boolean hot) {
  String hql = "from Category c where c.hot=:hot";
  return getSession().createQuery(hql)
   .setBoolean("hot", hot)
   .list();
 }
}
//ProductService接口
public interface ProductService extends BaseService<Product> { 

 //省略其他方法……
 //根据热点类别查询推荐商品(仅仅查询前4个)
 public List<Product> querByCategoryId(int cid);
} 

@SuppressWarnings("unchecked")
@Service("productService")
public class ProductServiceImpl extends BaseServiceImpl<Product> implements ProductService { 

 //省略其他方法…… 

 @Override
 public List<Product> querByCategoryId(int cid) {
  String hql = "from Product p join fetch p.category "
    + "where p.commend=true and p.open=true and p.category.id=:cid order by p.date desc";
  return getSession().createQuery(hql)
   .setInteger("cid", cid)
   .setFirstResult(0)
   .setMaxResults(4)
   .list();
 } 

}

2. 创建InitDataListener获取首页数据
后台完成了商品的显示逻辑业务,下面我们开始获取所需要的数据了。首先创建一个监听器InitDataListener继承ServletContextListener,关于监听器如何获取Spring配置文件,请参考这篇博文:监听器如何获取Spring配置文件

//@Component //监听器是web层的组件,它是tomcat实例化的,不是Spring实例化的。不能放到Spring中
public class InitDataListener implements ServletContextListener { 

 private ProductService productService = null;
 private CategoryService categoryService = null;
 private ApplicationContext context = null; 

 @Override
 public void contextDestroyed(ServletContextEvent event) {
  // TODO Auto-generated method stub 

 } 

 @Override
 public void contextInitialized(ServletContextEvent event) { 

  context = WebApplicationContextUtils.getWebApplicationContext(event.getServletContext());
  categoryService = (CategoryService) context.getBean("categoryService");//加载类别信息
  productService = (ProductService) context.getBean("productService");//加载商品信息 

  List<List<Product>> bigList = new ArrayList<List<Product>>(); //bigList中存放一个装有Category类的list
  // 1. 查询出热点类别
  for(Category category : categoryService.queryByHot(true)) {
   //根据热点类别id获取推荐商品信息
   List<Product> lst = productService.querByCategoryId(category.getId());
   bigList.add(lst); //将装有category的list放到bigList中
  }
  // 2. 把查询的bigList交给application内置对象
  event.getServletContext().setAttribute("bigList", bigList);
 } 

}

 好了,现在数据全都放到bigList这个集合中了。

3.首页UI页面设计

UI首页我们会从美工那拿到模板,这个模板是html,我们要做的就是将其改成我们的jsp,然后将bigList集合中的数据显示在首页上。首先我们将模板所需要的图片和css拷贝到WebRoot目录下,然后在WebRoot/public/head.jspf中将这两个文件引入即可,因为head.jspf是其他页面都要包含进来的公共头:

然后将模板中的html嵌到前台首页index.jsp中去,使用jstl标签修改一下显示内容,如下所示(只截图显示商品那一部分):

现在我们进入之前做好的后台添加商品页面,在女性休闲类添加几个商品,然后启动tomcat,运行一下首页index.jsp,效果如下:

 好了,前台的UI界面算是搭好了,接下来就是完成一些不同的业务了。

原文地址:http://blog.csdn.net/eson_15/article/details/51373403

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索ssh
, 框架
, 网上商城
商城首页UI设计
ssh框架网上商城、ssh框架网上商城项目、ssh框架电子商城代码、微信商城ui框架、商城ui框架,以便于您获取更多的相关知识。

时间: 2024-08-04 08:56:22

SSH框架网上商城项目第14战之商城首页UI的设计_java的相关文章

SSH框架网上商城项目第12战之添加和更新商品功能_java

添加商品部分原理和添加商品类别是一样的,参考文章:添加和更新商品类别,不过要比商品类别复杂,因为商品的属性有很多,对应的数据库中的字段也就多了,添加商品还有个选项是上传图片,这一小块内容会在下一篇文章中单独说明,因为这涉及到一个知识点,就是Struts2实现文件上传功能.其他废话不多说了,现在开始完善添加商品部分的代码:1. 添加商品1.1 添加商品的UI实现 首先完成query.jsp中添加商品部分的代码: 接下来我们看save.jsp中的具体实现: <%@ page language="

SSH框架网上商城项目第13战之Struts2文件上传功能_java

上一节我们做完了添加和更新商品的功能,这两个部分里有涉及到商品图片的上传,并没有详细解说.为此,这篇文章详细介绍一下Struts2实现文件上传的功能.1. 封装文件信息我们首先得有一个Model来封装文件的信息,这个Model里需要有三个属性:文件.文件类型和文件名.针对我们要传的图片,我们新建一个Model如下: public class FileImage { private File file; private String contentType; private String file

SSH框架网上商城项目第10战之搭建商品类基本模块_java

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

SSH框架网上商城项目第2战之基本增删查改、Service和Action的抽取_java

上一节<SSH框架网上商城项目第1战之整合Struts2.Hibernate4.3和Spring4.2>我们搭建好了Struts2.Hibernate和Spring的开发环境,并成功将它们整合在一起.这节主要完成一些基本的增删改查以及Service.Dao和Action的抽取.1. Service层的抽取        上一节中,我们在service层简单写了save和update方法,这里我们开始完善该部分的代码,然后对service层的代码进行抽取.1.1 完善CategoryServic

SSH框架网上商城项目第4战之EasyUI菜单的实现_java

上篇文章我们使用EasyUI搭建了后台页面的框架,点击这里查看,这一节我们主要使用EasyUI技术简单实现后台菜单,先将简单功能做出来,后期再继续丰富. 1. 实现左侧菜单  首先看一下效果图: 我们可以点击"基本操作"和"其他操作"来切换菜单选项,在具体的选项内,点击不同的连接,会在右侧显示出来.我们先把左边的菜单做出来. 左侧菜单内容主要有两个:"类别管理"和"商品管理".我们知道,上一节中,在aindex.jsp中应将后

SSH框架网上商城项目第8战之查询和删除商品类别功能实现_java

上一节我们完成了使用DataGrid显示所有商品信息,这节我们开始添加几个功能:添加.更新.删除和查询.首先我们实现下前台的显示,然后再做后台获取数据.1. 添加.更新.删除和查询功能的前台实现DataGrid控件里有个toolbar属性,是添加工具栏的,我们可以在toolbar属性中添加这些按钮来实现相应的功能.先看一下官方文档对toolbar的定义: 我们使用数组的方式定义工具栏,在query.jsp页面中新添加如下代码: <%@ page language="java" i

SSH框架网上商城项目第6战之基于DataGrid的数据显示_java

EasyUI中DataGrid以表格形式展示数据,并提供了丰富的选择.排序.分组和编辑数据的功能支持.DataGrid的设计用于缩短开发时间,并且使开发人员不需要具备特定的知识.它是轻量级的且功能丰富.单元格合并.多列标题.冻结列和页脚只是其中的一小部分功能. 1. 回顾一下第4节内容 在第4节中,我们使用EasyUI搭建好了左侧菜单栏,并且通过点击菜单选项在右边弹出对应的选项卡.这节我们来使用DataGrid把右边的选项卡部分做好.先看一下第4节中最后的aindex.jsp文件(也可参见第4节

SSH框架网上商城项目第9战之添加和更新商品类别功能实现_java

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

SSH框架网上商城项目第25战之使用java email给用户发送邮件_java

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