1)HTML注释:
<!-- 注释内容 [ <%= 表达式 %> ] -->
可以用注释内容
,
也可以用表达式
.
2)
隐藏注释:
<%-- 注释内容 --%>
注释会被
JSP
编译时被忽略
.
编译器不会对
<%-- --%>
之间的语句编译
,
它不会显示在客户的浏览器和源代码中
.
3)声明:
<%!
声明变量or
方法 %>
声明你将要在
JSP
程序中用到的变量和方法
.
可以一次性声明多个变量和方法,要以
";"
结尾
,
声明在
Java
中要合法
.
4)表达式:
<%= 表达式 %>
JAVA
中的表达式
,
会被显示在
JSP
页面中
,
注意不要有
";".
5)JAVA代码:
<% JAVA代码 %>
包含有效
JAVA
代码
.
6)Include指令:
<%@ include file="相对路径" %>
可以包含
HTML,JSP,
文本文件
,JAVA
代码
,
要注意在这个包含文件中不能使用
<html><body>
有时会导致错误
.
属性
:
file
指相对路径
,
如
:"error.jsp""templates/onlinestore.html""/beans/calendar.jsp"
如果这个路径以
"/"
开头,那么这个路径主要是参照
JSP
应用的上下关系路径,如果路径是以文件名或目录名开头,那么这个路径就是正在使用的
JSP
文件的当前路径
.
7)Page指令:
<%@ page
[ language="java" ]
[ extends="package.class" ]
[ import="{package.class | package.*}, ..." ]
[ session="true | false" ]
[ buffer="none | 8kb | sizekb" ]
[ autoFlush="true | false" ]
[ isThreadSafe="true | false" ]
[ info="text" ]
[ errorPage="relativeURL" ]
[ contentType="mimeType [ ;charset=characterSet ]" | "text/html ; charset=ISO-
8859-1" ]
[ isErrorPage="true | false" ]
%>
属性
:
-language="java"
声明脚本语言的种类,暂时只能用
"java"
-extends="package.class"
继承一个类
-import="{package.class | package.* }, ..."
导入一个包
,
下面的包是默认自动导入的
.
java.lang.*,javax.servlet.*,javax.servlet.jsp.*,javax.servlet.http.*
-session="true | false"
是否允许
session
会话
,
默认
true.
-buffer="none | 8kb | sizekb"
设置缓冲区大小默认值是
8kb,none
是关闭缓冲区
,sizekb
是自己设置大小
.
-autoFlush="true | false"
是否刷新缓冲区
,true(
缺省值
)
输出正常
,false
这个
buffer
溢出
,
就会导致一个错误
,buffer
设置为
none,
就要把这个设置为
false.
-isThreadSafe="true | false"
设置
Jsp
文件是否能多线程使用。缺省值是
true.
-info="text"
就是
JSP
的一些信息
,
能够使用
Servlet.getServletInfo
方法取回
.
-errorPage="relativeURL"
指定接收
Exception
对象的
JSP
页面的
URL.
-isErrorPage="true | false"
设置是否接收一个
Exception
对象
.
-contentType="text/html;charset=ISO-8859-1"
设置页面类型和字符集
.
缺省类型是
:text/html,
缺省字符集为
ISO-8859-1.
8)<jsp:forward>标签:
<jsp:forward page="URL or 表达式"/>
<jsp:forward page="URL or 表达式">
<jsp:param name="
参数名
" value="
参数值
or
表达式
" /></jsp:forward>
转发一个
request
对象
.<jsp:param>
可以传参
,
目标文件必须能够处理参数
.
如果使用非缓冲输
出
,
而且在使用
<jsp:forward>
之前
,jsp
文件已经有了数据
,
那么文件执行就会出错
.
属性
:
-page="URL or
表达式
"
要转发的文件
URL
或者是一个代表
URL
的表达式
.
-<jsp:param name="
参数名
" value="
参数值
or
表达式
" />name
参数名
value
参数值
.
9)<jsp:include>标签:
<jsp:include page="URL or 表达式" flush="true" />
<jsp:include page="URL or 表达式" flush="true" >
<jsp:param name="参数名" value="参数值 or 表达式" />+
</jsp:include>
允许包含动态文件和静态文件
,
动态的会被
Jsp
编译器执行
.
不能从文件名上判断是动态的还是静态的
.<jsp:param>
可以传递参数
.
属性
:
-page="URL or
表达式
"
要包含文件的相对路径
,
或者是代表相对路径的表达
.
式
.
-flush="true"
这里你必须使用
flush="true",
你不能使用
false
值
.
缺省值为
false.
<jsp:param>
能传递一个或多个参数给动态文件
,
能在一个页面中使用多个
<jsp:param>
来传递多个参数
.
10)<jsp:getProperty>标签:
<jsp:getProperty name="Bean
实例名" property="
属性名" />
获得
Bean
的属性值之前
,
必须用
<jsp:useBean>
创建
Bean.name
指定新建
Bean
的
id.
只能
JavaBean
属性
:
-name="bean
的名字
"
由
<jsp:useBean>
的
id
属性指定
.
-property="bean
的属性
"
所指定的
Bean
的属性名
.
11)<jsp:setProperty>标签:
<jsp:setProperty
name="Bean的id"
{
property= "*"
property="propertyName" [ param="parameterName" ]
property="propertyName" value="{string | <%= expression %>}"
}/>
<jsp:setProperty>
的
name
的值应当于
<jsp:useBean>
中
id
的值
多种方法来设定属性值
:
通过用户输入的所有值
(
被做为参数储存中
request
对象中
)
来匹配
Bean
中的属性
通过用户输入的指定的值来匹配
Bean
中指定的属性
在运行时使用一个表达式来匹配
Bean
的属性
属性
:
-name="Bean
名称
"
表示已经在
<jsp:useBean>
中的
id
设置的
Bean
变量
.
-property="Bean
属性名
" value="
要设置的属性名
"
如果你使用了
property="*",
那么
Bean
的属性没有必要按
Html
表单中的顺序排序
.
-property="*"
储存用户在
Jsp
输入的所有值
,
用于匹配
Bean
中的属性
.
在
Bean
中的属性的名字必须和
request
对象中的参数名一致
.
从客户传到服器上的参数值一般都是字符类型
,
这些字符串为了能够在
Bean
中匹配就必须转换成其它的类型
,
下面的表中列出了
Bean
属性的类型以及他们的转换方法
.
把字符串转化为其它
类型的方法
,Property
类型方法
:
boolean or Boolean
java.lang.Boolean.valueOf(String)
byte or Byte
java.lang.Byte.valueOf(String)
char or Character
java.lang.Character.valueOf(String)
double or Double
java.lang.Double.valueOf(String)
integer or Integer
java.lang.Integer.valueOf(String)
float or Float
java.lang.Float.valueOf(String)
long or Long
java.lang.Long.valueOf(String)
12)<jsp:useBean>标签:
<jsp:useBean
id="beanInstanceName"
scope="page | request | session | application"
{
class="package.class" |
type="package.class" |
class="package.class" type="package.class" |
beanName="{package.class | <%= expression %>}" type="package.class"
}
/>other elements</jsp:useBean>
用于创建一个
JavaBeans
组件
,
首先会试图定位一个
Bean
实例,如果不存在,那么就会从创建一个新的
.
属性
:
-id="
创建的
Bean
变量名称
"
在你所定义的范围中确认
Bean
的变量,你能在后面的程序中使用此变量名来分辨不同的
Bean
这个变量名对大小写敏感,如果这个
Bean
已经在别的
<jsp:useBean>
中创建,那么这个
id
的值必须与原来的那个
id
值一致
.
-scope="page | request | session | application"Bean
存在的范围以及
id
变量名的有效范围
.
缺省值是
page.
13)<jsp:plugin>标签:
<jsp:plugin
type="bean | applet"
code="classFileName"
codebase="classFileDirectoryName"
[ name="instanceName" ]
[ archive="URIToArchive, ..." ]
[ align="bottom | top | middle | left | right" ]
[ height="displayPixels" ]
[ width="displayPixels" ]
[ hspace="leftRightPixels" ]
[ vspace="topBottomPixels" ]
[ jreversion="JREVersionNumber | 1.1" ]
[ nspluginurl="URLToPlugin" ]
[ iepluginurl="URLToPlugin" ] >
[ <jsp:params>
[ <jsp:param name="parameterName" value="{parameterValue | <%= expression %>}" />
[ </jsp:params> ]
[ <jsp:fallback> text message for user </jsp:fallback> ]
</jsp:plugin>
用于在浏览器中播放或显示一个对象
(
典型的就是
applet
和
Bean),
而这种显示需要在浏览器的
java
插件
.
当
Jsp
文件被编译
,
送往浏览器时
,<jsp:plugin>
标签将会根据浏览器的版本替换成
<object>
或者
<embed>
元素
.
注意
<object>
用于
HTML 4.0 ,<embed>
用于
HTML 3.2.
一般来说
,
这个标签会指定对象是
Applet
还是
Bean,
同样也会指定
class
的名字
,
还有位置
,
另外还会指定将从哪里下载这个
Java
插件
.
属性
:
-type="bean | applet"
将被执行的插件对象的类型
,
你必须得指定这个是
Bean
还是
applet,
因为这个属性没有缺省值
.
-code="classFileName"
将会被
Java
插件执行的
Java Class
的名字
,
必须以
.class
结尾
,
这个文件必须存在于
codebase
属性指定的目录中
.
-codebase="classFileDirectoryName"
将会被执行的
Java Class
文件的目录
(
或者是路径
),
如果你没有提供此属性
,
使用本标签的
JSP
文件的目录会被使用
.
-name="instanceName"
这个
Bean
或
applet
实例的名字
,
它将会在
Jsp
其它的地方调用
.
-archive="URIToArchive, ..."
一些由逗号分开的路径名
,
这些路径名用于预装一些将要使用的
class,
这会提高
applet
的性能
.
类似于
classpath.
-align="bottom | top | middle | left | right"
图形
,
对象
,Applet
的位置
.