JSP技术(3)传智书城

【任务目标】:
通过学习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" />&nbsp;<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 &copy; 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 />
  为了让大家有更好的购物体验,325日起,当日达业务关小黑屋回炉升级!<br />具体开放时间请留意公告,感谢大家的支持与理解,祝大家购物愉快!<br />
        323<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

  • 1
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值