如何使用“<%= request.getContextPath()%>”比“../”更好

时间:2013-11-01 10:05:18

标签: jsp contextpath

我参与了许多J2EE项目,其中视图层是JSP。在大多数项目中,我看到我们使用scriptlet中的contextPath引用外部资源,即images,javascript,jsp,css等。

代码如下,

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>GC Demo Using HandlebarsJS</title>
    <script type="text/javascript" src="<%=request.getContextPath()%>/js/jqueryUI-AutoComplete/jquery-1.9.1.js"></script>
    <script type="text/javascript" src="<%=request.getContextPath()%>/js/jqueryUI-AutoComplete/jquery-ui-1.10.3.custom.js"></script>
    <script type="text/javascript" src="<%=request.getContextPath()%>/js/handlebarsJS/handlebars.js"></script>
    <link rel="stylesheet" type="text/css" href="${pageContext.servletContext.contextPath}/js/jqueryUI-AutoComplete/jquery-ui-1.10.3.custom.css">

从上面的jsp中,我在这里导入了同一个项目包中的外部资源,即在我的战争中。

现在上面的JSP可以编写如下代码,

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>GC Demo Using HandlebarsJS</title>
    <script type="text/javascript" src="../js/jqueryUI-AutoComplete/jquery-1.9.1.js"></script>
    <script type="text/javascript" src="../js/jqueryUI-AutoComplete/jquery-ui-1.10.3.custom.js"></script>
    <script type="text/javascript" src="../js/handlebarsJS/handlebars.js"></script>
    <link rel="stylesheet" type="text/css" href="../js/jqueryUI-AutoComplete/jquery-ui-1.10.3.custom.css">

在第二个例子中,我也引用了战争中的资源。

现在考虑上述两种情况,第一种情况作为最佳实践更具意义。

为什么?

使用第二种情况有什么缺点?

使用第二种情况,我们的项目是否与contextpath紧密耦合?

请向我解释。

1 个答案:

答案 0 :(得分:52)

request.getContextPath()-返回应用程序的根路径,而 ../ - 返回文件的父目录。

您使用request.getContextPath(),因为它始终指向您的应用程序的根目录。如果要将jsp文件从一个目录移动到另一个目录,则无需更改任何内容。 现在,考虑第二种方法。如果您要将jsp文件从一个文件夹移动到另一个文件夹,则必须在引用文件的每个位置进行更改。

此外,使用request.getContextPath()的更好方法是在变量中设置'request.getContextPath()'并使用该变量来引用您的路径。

<c:set var="context" value="${pageContext.request.contextPath}" />
<script src="${context}/themes/js/jquery.js"></script>

PS-这是我能弄明白的原因之一。不知道它是否有任何意义。