JSP模版元素
1.JSP頁面中的HTML內容稱之為JSP模版元素。
2.JSP模版元素定義了網頁的基本骨架,即定義了頁面的結構和外觀。
JSP腳本表達式
1.JSP腳本表達式(expression)用於將程序數據輸出到客戶端
語法:<%= 變量或表達式 %>
舉例:當前時間:<%= new java.util.Date() %>
2.JSP引擎在翻譯腳本表達式時,會將程序數據轉成字符串,然後在相應位置用out.print(…) 將數據輸給客戶端。
3.JSP腳本表達式中的變量或表達式後面不能有分號(;)
JSP腳本片斷(1)
1.JSP腳本片斷(scriptlet)用於在JSP頁面中編寫多行Java代碼。語法:
<%
多行java代碼
%>
2.注意:JSP腳本片斷中只能出現java代碼,不能出現其它模板元素, JSP引擎在翻譯JSP頁面中,會將JSP腳本片斷中的Java代碼將被原封不動地放到Servlet的_jspService方法中。
3.JSP腳本片斷中的Java代碼必須嚴格遵循Java語法,例如,每執行語句後面必須用分號(;)結束。
JSP腳本片斷(2)
1.在一個JSP頁面中可以有多個腳本片斷,在兩個或多個腳本片斷之間可以嵌入文本、HTML標記和其他JSP元素。
舉例:
[html]
<%
int x = 10;
out.println(x);
%>
<p>這是JSP頁面文本</p>
<%
int y = 20;
out.println(x);
%>
2.多個腳本片斷中的代碼可以相互訪問,猶如將所有的代碼放在一對<%%>之中的情況。如:out.println(x);
3.單個腳本片斷中的Java語句可以是不完整的,但是,多個腳本片斷組合後的結果必須是完整的Java語句,例如:
[html] view plaincopy
<%
for (int i=1; i<5; i++)
{
%>
<H1>www.it315.org</H1>
<%
}
%>
JSP聲明
JSP頁面中編寫的所有代碼,默認會翻譯到servlet的service方法中, 而Jsp聲明中的java代碼被翻譯到_jspService方法的外面。語法:
<%!
java代碼
%>
所以,JSP聲明可用於定義JSP頁面轉換成的Servlet程序的靜態代碼塊、成員變量和方法 。
多個靜態代碼塊、變量和函數可以定義在一個JSP聲明中,也可以分別單獨定義在多個JSP聲明中。
JSP隱式對象的作用范圍僅限於Servlet的_jspService方法,所以在JSP聲明中不能使用這些隱式對象。
案例
[html]
<%!
static
{
System.out.println("loading Servlet!");
}
private int globalVar = 0;
public void jspInit()
{
System.out.println("initializing jsp!");
}
%>
<%!
public void jspDestroy()
{
System.out.println("destroying jsp!");
}
%>
JSP注釋
JSP注釋的格式:
<%-- 注釋信息 --%>
JSP引擎在將JSP頁面翻譯成Servlet程序時,忽略JSP頁面中被注釋的內容。
注釋
有三種注釋方式
HTML注釋(輸出注釋):指在客戶端查看源代碼時能看見注釋。例如,
<!-- this is an html comment.it will show up int the response. -->
JSP頁注釋(隱藏注釋):指注釋雖然寫在JSP程序中,但不會發送給客戶,因此在客戶端查看源代碼時不能看見注釋。這樣的注釋在JSP編譯時被忽略掉。
<%--this is a JSP comment.it will only be seen in jsp code--%>
Java注釋:只能出現在Java代碼區中,不允許直接出現在頁面中。//單行注釋 /*多行注釋*/
實例
編寫index1.jsp頁面,頁面中提供兩個輸入文本框,用來收集用戶提交的數據,並提供“提交”和“取消”按鈕,方便用戶提交或取消相應的操作。
編寫result1.jsp頁面,根據用戶提交的數字,顯示基於這個數字所形成的乘法表。
案例源碼:
//Index1.jsp
[html]
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'index1.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<body background="images/tupian.jpg">
<center>
<p align="center">請輸入兩個自然數給你打印乘法口訣表</p>
<form action="jiujiu.jsp" method="post">
<table border="2px" cellpadding="0" cellspacing="0">
<tr>
<td>startNumber:</td>
<td><input type="text" name="startNumber"/></td>
</tr>
<tr>
<td>endNumber:</td>
<td><input type="text" name="endNumber"/></td>
</tr>
<tr>
<td><center><input type="submit" value="提交"></td>
<td><center><input type="reset" value="重置"/></td>
</tr>
</table>
</form>
</center>
</body>
</html>
//result1.jsp
[html]
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'jiujiu.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<body>
<font size=12 color=red>親,這就是你想要的乘法口訣表!!</font>
<br>
<%
//int startNum=Integer.valueOf(request.getParameter("startNumber"));
int startNum=Integer.parseInt(request.getParameter("startNumber"));
//int endNum=Integer.valueOf(request.getParameter("endNumber"));
int endNum=Integer.parseInt(request.getParameter("endNumber"));
for(int i=startNum; i<=endNum; i++)
{
for(int j=1; j<=i; j++) www.2cto.com
{
out.print(j+"*"+i+"="+(i*j)+"\t");
out.print(" ");
}
out.print("<br/>");
}
%>
</body>
</html>