【任务目标】:
通过学习JSP知识,使用JSP技术,完成传智书城首页的展示。
【实现步骤】
1.首页设置
在chapter7项目的WebContent目录创建一个名称为index.jsp的页面文件,该文件使用<jsp:forward>动作元素跳转到项目客户端展示的首页,其主要代码如下所示。
<body>
<jsp:forward page="client/index.jsp"></jsp:forward>
</body>
2.文件移植
将第第一章中传智书城的文件复制到WebContent目录下,并将client文件夹下的所有.html文件改名为.jsp文件,修改后client文件下如图所示。
如果此时运行项目。访问网页使会发现页面的中文都是乱码。其实,要想解决此问题很简单只需将JSP文件中都加上page指令即可,其代码如下:
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
添加page指令后,重新启动Tomact服务器,再次访问index.jsp页面,这时所有中文就正确显示了。
3,修改JSP页面中的地址和链接,但是他会出现404报错。而这时怎么回事呢,我们可以了解到当点击“新用户注册”链接后,所访问的链接/chapter7/register.jsp,而项目注册页面的真实路径是/chapter7/client/register.jsp,所以出现了404的错误,要解决此问题,只需在index.jsp页面文件中的链接和图片等路径前,加入“"${pageContext.request.contextPath}/client/#">”即可。修改后链接如下:
<a href="${pageContext.request.contextPath}/client/register.jsp">新用户注册</a>
在上面链接代码中,EL表达式${pageContext.request.contextPath}会获取项目的名称chapter7并以“/”开头,这样查找项目中的文件时,是以绝对路径查找的,项目中只要有相应文件,就不会出现找不到文件的错误。此时在文件index.jsp页面,点击“新用户注册”连接后,就可以成功进入注册页面了。为了避免项目中的JS,CSS和图片等文件也出现找不到文件的错误,所以需要将所有JSP文件中的相关链接"{pageContext.request.contextPath}/client/"
4.抽取页面代码
虽然已经成功将HTML文件改为了JSP文件,并能够成功访问,但是在index.jsp页面和register.jsp中包含了大量的重复代码(如两个页面中的头部、菜单列表以及页面底部代码)。通常一个项目中的头部和底部是固定的,如果每一个页面都有这些代码,会使项目十分臃肿,不利于项目的开发和维护。此时,可以将项目的重复代码抽取·出到一个新的JSP页面,然后通过JSP的include指令引入这些抽取出的JSP页面。具体如下
(1)在client文件下创建一个名称为head.jsp的文件,将传智书城index.jsp中顶部的代码抽取到head.jsp中。其中,head.jsp页面的代码如下所示:
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<div id="divhead">
<table cellspacing="0" class="headtable">
<tr>
<td>
<a href="${pageContext.request.contextPath}/client/#">
<img src="${pageContext.request.contextPath}/client/images/logo.png" width="200" height="60" border="0" />
</a>
</td>
<td style="text-align:right">
<img src="${pageContext.request.contextPath}/client/images/cart.gif" width="26" height="23" style="margin-bottom:-4px" /> <a href="${pageContext.request.contextPath}/client/#">购物车</a>
| <a href="${pageContext.request.contextPath}/client/#">帮助中心</a>
| <a href="${pageContext.request.contextPath}/client/#">我的帐户</a>
| <a href="${pageContext.request.contextPath}/client/register.jsp">新用户注册</a>
</td>
</tr>
</table>
</div>
(2)在client文件下创建一个名称为menu_search.jsp的文件,将传智书城index.jsp中菜单列表中的代码抽取到menu_search.jsp中,其中menu_serch.jsp页面的代码:
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<div id="divmenu">
<a href="${pageContext.request.contextPath}/client/#">文学</a>
<a href="${pageContext.request.contextPath}/client/#">生活</a>
<a href="${pageContext.request.contextPath}/client/#">计算机</a>
<a href="${pageContext.request.contextPath}/client/#">外语</a>
<a href="${pageContext.request.contextPath}/client/#">经管</a>
<a href="${pageContext.request.contextPath}/client/#">励志</a>
<a href="${pageContext.request.contextPath}/client/#">社科</a>
<a href="${pageContext.request.contextPath}/client/#">学术</a>
<a href="${pageContext.request.contextPath}/client/#">少儿</a>
<a href="${pageContext.request.contextPath}/client/#">艺术</a>
<a href="${pageContext.request.contextPath}/client/#">原版</a>
<a href="${pageContext.request.contextPath}/client/#">科技</a>
<a href="${pageContext.request.contextPath}/client/#">考试</a>
<a href="${pageContext.request.contextPath}/client/#">生活百科</a>
<a href="${pageContext.request.contextPath}/client/#" style="color:#FFFF00">全部商品目录</a>
</div>
<div id="divsearch">
<form action="#" id="searchform">
<table width="100%" border="0" cellspacing="0">
<tr>
<td style="text-align:right; padding-right:220px">
Search
<input type="text" name="textfield" class="inputtable" id="textfield" value="请输入书名"
onmouseover="this.focus();"
onclick="my_click(this, 'textfield');"
onBlur="my_blur(this, 'textfield');"/>
<a href="${pageContext.request.contextPath}/client/#">
<img src="${pageContext.request.contextPath}/client/images/serchbutton.gif" border="0" style="margin-bottom:-4px" onclick="search()"/>
</a>
</td>
</tr>
</table>
</form>
</div>
(3)在client文件下创建一个名称为foot.jsp的文件,将传智书城index.jsp中底部的代码抽取出到foot.jsp中.其中,foot.jsp页面的代码如下所示:
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<div id="divfoot">
<table width="100%" border="0" cellspacing="0" >
<tr>
<td rowspan="2" style="width:10%">
<img src="${pageContext.request.contextPath}/client/images/logo.png" width="195" height="50"
style="margin-left:175px" />
</td>
<td style="padding-top:5px; padding-left:50px">
<a href="${pageContext.request.contextPath}/client/#">
<font color="#747556"><b>CONTACT US</b></font>
</a>
</td>
</tr>
<tr>
<td style="padding-left:50px">
<font color="#CCCCCC">
<b>COPYRIGHT 2015 © BookStore All Rights RESERVED.</b>
</font>
</td>
</tr>
</table>
</div>
(4)使用include指令抽取出的三个JSP页面包含在index.jsp中,其主要代码如下所示:
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>首页</title>
<link rel="stylesheet" href="${pageContext.request.contextPath}/client/css/main.css" type="text/css" />
<!-- 导入首页轮播图css和js脚本 -->
<link type="text/css" href="${pageContext.request.contextPath}/client/css/autoplay.css" rel="stylesheet" />
<script type="text/javascript" src="${pageContext.request.contextPath}/clientjs/autoplay.js"></script>
</head>
<body class="main">
<!-- 1.网上书城顶部 start -->
<%@include file="head.jsp" %>
<!-- 网上书城顶部 end -->
<!-- 2.传智舒城菜单列表 start -->
<%@include file="menu_search.jsp" %>
<!-- 传智舒城菜单列表 end -->
<!-- 3.网上书城首页轮播图 start -->
<div id="box_autoplay">
<div class="list">
<ul>
<li><img src="${pageContext.request.contextPath}/client/ad/index_ad1.jpg" width="900" height="335" /></li>
<li><img src="${pageContext.request.contextPath}/client/ad/index_ad2.jpg" width="900" height="335" /></li>
<li><img src="${pageContext.request.contextPath}/client/ad/index_ad3.jpg" width="900" height="335" /></li>
<li><img src="${pageContext.request.contextPath}/client/ad/index_ad4.jpg" width="900" height="335" /></li>
<li><img src="${pageContext.request.contextPath}/client/ad/index_ad5.jpg" width="900" height="335" /></li>
</ul>
</div>
</div>
<!-- 网上书城首页轮播图 end -->
<!--4. 公告板和本周热卖 start -->
<div id="divcontent">
<table width="900px" border="0" cellspacing="0">
<tr>
<td width="497">
<img src="${pageContext.request.contextPath}/client/images/billboard.gif" width="497" height="38" />
<table cellspacing="0" class="ctl">
<tr>
<td width="485" height="29">
尊敬的网上书城用户, <br />
为了让大家有更好的购物体验,3月25日起,当日达业务关小黑屋回炉升级!<br />具体开放时间请留意公告,感谢大家的支持与理解,祝大家购物愉快!<br />
3月23日<br />
传智播客 网上书城系统管理部<br />
</td>
</tr>
</table>
</td>
<td style="padding:5px 15px 10px 40px">
<table width="100%" border="0" cellspacing="0">
<tr>
<td>
<img src="${pageContext.request.contextPath}/client/images/hottitle.gif" width="126" height="29" />
</td>
</tr>
</table>
<table width="100%" border="0" cellspacing="0">
<tr>
<td style="width:80; text-align:center">
<a href="${pageContext.request.contextPath}/client/#">
<img src="${pageContext.request.contextPath}/client/bookcover/105.jpg" width="102" height="130" border="0" />
</a>
<br />
</td>
<td style="width:80; text-align:center">
<a href="${pageContext.request.contextPath}/client/#">
<img src="${pageContext.request.contextPath}/client/bookcover/106.jpg" width="102" height="130" border="0" />
</a>
<br />
</td>
</tr>
</table>
</td>
</tr>
</table>
</div>
<!-- 公告板和本周热卖 end -->
<!--5. 网上书城底部 start -->
<%@include file="foot.jsp" %>
<!-- 网上书城底部 end -->
</body>
</html>
在文件中,使用include指令分别将head.jsp、menu_search.jsp、foot.jsp3个页面包含了index.jsp中。此中写法,不但减少了页面中的代码量,而且提高了代码的复用性。启动Tomact服务器,在浏览器地址栏输入“http://localhost:10081/chapter7/client/index.jsp”其浏览器效果如下图所示:
跳转至新用户注册为:
2020080603052