Jsp_Servlet_JavaBean_Chapter08_理论笔记

1、EL表达式的使用
* 语法: ${表达式}
EL: Expression Lanuage(表达式语言)
注意:EL表达式只能在支持Servlet2.4和Jsp2.0的容器上才能使用。
表达式=运算符+操作数

* 运算符
a) 算术运算符:+ - * /(div) %(mod)
b) 逻辑元算符:&&(and) ||(or) !(not)
c) 比较运算符:>(gt:great than) <(lt:less than) >=(ge:great and equal) <=(le:less and equal) ==(eq:equal) !=(ne:not equal)
d) 条件运算符: ? :
e) 空运算符: empty:null, ""
说明: 与Java中的运算符比较:多一个空运算符,少赋值运算符

* 操作数
常量
a) 整型
b) 小数
c) 布尔型
d) 字符型(用单引号或双引号均可)
e) 空(null)

变量:
a) 实质:四个标准范围的属性
b) 变量的搜索顺序:按照范围从小到大的顺序搜索:pageContext < request < session < application
c) 变量的访问:可以通过.运算符或者[]运算符访问

隐式对象
a) 与作用范围有关的: pageScope, requestScope, sessionScope, applicationScope
b) 与输入有关的: param, paramValues
c) pageContext:通过这个隐式对象可以访问到request, session, servletContext
d) header, cookie

* 使用场合
a) 用于html标签中
b) 与JavaBean结合使用: 创建的JavaBean必须要放到某一个标准范围中,提供相应的get方法进行对象导航
c) 与jstl结合使用
d) 其他用法:el表达式输出Map, List, 数组和对象数组中的值

2、JSTL的使用
* 基本概念:Jsp Standard Taglib Library,主要用于提供无脚本环境
注意:JSTL只能够在支持Servlet2.4和Jsp2.0的容器上才能正常使用。

* 分类
a) 核心标签库:通用标签库,条件标签库,迭代标签库
b) I18N标签库
c) SQL标签库
d) XML标签库
e) 函数库

在使用JSTL的时候,首先要将JSTL库导入到当前工程中,并且在Jsp页面中通过taglib指令将标签库描述符文件导入

* 核心标签库
a) 通用标签库:用于在JSP页面内设置、删除变量和显示变量的值
set:
功能:设置指定范围内的变量值,如果该变量不存在,则创建它。
语法:<c:set value=”value” var=”varName” [scope=”{page|request|session|application}”]/>
var:指定变量的名称,value:指定变量的值 scope:指定变量的存储范围,默认为page

remove:
功能:用于删除变量
语法:<c:remove var=”varName” [scope=”{page|request|session|application}”]/>
var:指定要删除的变量名 scope:指定变量的存储范围

out:
功能:计算表达式并将结果显示在页面上
语法:<c:out value=”value” [escapeXml=”{true|false}”] [default=”defaultValue”] />
<c:out value=”value” [escapeXml=”{true|false}”]>
default value
</c:out>
value:指定表达式或变量 default:指定输出的默认值 escapteXml:如果value中包含<,>,&,',"
等特殊字符,在输出的时候是否将其转换为其对应的字符实体代码。默认值为true.

b) 条件标签库:用于控制程序执行流程

if(....) {
....
}

if
语法:<c:if test=”testCondition” var=”varName” [scope=”{page|request|session|application}”]/>
<c:if test=”testCondition” [var=”varName”] [scope=”{page|request|session|application}”]>
body content
</c:if>
test:指定条件表达式 var:指定变量名 scope:指定变量存储的范围

switch...case...

choose:
语法:<c:choose>
<c:when test=”testCondition1”>
body content
</c:when>
<c:when test=”testCondition2”>
body content
</c:when>
...
<c:otherwise>
conditional block
</c:otherwise>
</c:choose>
test:指定条件表达式

c) 迭代标签库
forEach:(相当于java中的for循环)
语法:<c:forEach [var=”varName”] items=”collection” [varStatus=”varStatusName”] [begin=”begin”] [end=”end”] [step=”step”]>
body content
</c:forEach>

<c:forEach [var=”varName”][varStatus=”varStatusName”]begin=”begin” end=”end” [step=”step”]>
body content
</c:forEach>
items:指定要迭代的集合 var:指定变量名 varStatus:指定迭代计数变量名 begin:指定迭代集合的开始标号
end:指定迭代集合的结束标号 step:指定迭代步长

示例:对List,Set,Map,数组的循环遍历

forTokens:
<c:forTokens items="stringOfTokens" delims="delimiters" [var="varName"] [varStatus="varStatusName"] [begin="begin"] [end="end"] [step="step"]>
body content
</c:forTokens>
items:指定要迭代的字符串 delims:指定字符串中的分隔符 var:指定变量名 varStatus:指定迭代中的计数变量
begin:指定迭代的起始标号 end:指定迭代的结束标号 step:指定迭代步长

* I18N标签库
formatNumber
功能:格式化数字
语法:<fmt:formatNumber value=”numericValue”
[type=”{number|currency|percent}”]
[pattern=”customPattern”]
[currencyCode=”currencyCode”]
[currencySymbol=”currencySymbol”]
[groupingUsed=”{true|false}”]
[maxIntegerDigits=”maxIntegerDigits”]
[minIntegerDigits=”minIntegerDigits”]
[maxFractionDigits=”maxFractionDigits”]
[minFractionDigits=”minFractionDigits”]
[var=”varName”]
[scope=”{page|request|session|application}”]/>]

<fmt:formatNumber [type=”{number|currency|percent}”]
[pattern=”customPattern”]
[currencyCode=”currencyCode”]
[currencySymbol=”currencySymbol”]
[groupingUsed=”{true|false}”]
[maxIntegerDigits=”maxIntegerDigits”]
[minIntegerDigits=”minIntegerDigits”]
[maxFractionDigits=”maxFractionDigits”]
[minFractionDigits=”minFractionDigits”]
[var=”varName”]
[scope=”{page|request|session|application}”]>
numeric value to be formatted
</fmt:formatNumber>

formatDate
功能:格式化日期
语法:<fmt:formatDate value="date"
[type="{time|date|both}"]
[dateStyle="{default|short|medium|long|full}"]
[timeStyle="{default|short|medium|long|full}"]
[pattern="customPattern"]
[timeZone="timeZone"]
[var="varName"]
[scope="{page|request|session|application}"]/>


* SQL标签库
setDataSource
功能:设置数据源

语法:<sql:setDataSource {dataSource="dataSource" | url="jdbcUrl"
[driver="driverClassName"]
[user="userName"]
[password="password"]}
[var="varName"]
[scope=”{page|request|session|application}”]/>

示例:<sql:setDataSource driver="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/studentdb"
user="root"
password="root"
var="con"
scope="page" />

query
功能:执行数据库查询

语法:
<sql:query sql="sqlQuery"
var="varName" [scope=”{page|request|session|application}”]
[dataSource=”dataSource”]
[maxRows="maxRows"]
[startRow="startRow"]/>

<sql:query sql="sqlQuery"
var="varName" [scope=”{page|request|session|application}”]
[dataSource=”dataSource”]
[maxRows="maxRows"]
[startRow="startRow"]>
<sql:param> actions
</sql:query>

<sql:query var="varName"
[scope=”{page|request|session|application}”]
[dataSource=”dataSource”]
[maxRows="maxRows"]
[startRow="startRow"]>
query
optional <sql:param> actions
</sql:query>

示例:
<sql:query var="rows" dataSource="${con}">
select * from student
</sql:query>

<sql:query var="rows" dataSource="${con}">
select * from student where sid = ?
<sql:param value="1" />
</sql:query>

update
功能:执行数据库更新

语法:
<sql:update sql="sqlUpdate"
[dataSource=”dataSource”]
[var="varName"] [scope=”{page|request|session|application}”]/>

<sql:update sql="sqlUpdate"
[dataSource=”dataSource”]
[var="varName"] [scope=”{page|request|session|application}”]>
<sql:param> actions
</sql:update>

<sql:update [dataSource=”dataSource”]
[var="varName"] [scope=”{page|request|session|application}”]>
update statement
optional <sql:param> actions
</sql:update>

示例:
<sql:transaction dataSource="${con}">
<sql:update var="rowCount">
update student set stuAge = ? where sid = ?
<sql:param value="100" />
<sql:param value="2" />
</sql:update>
</sql:transaction>

transaction
功能:执行事务

语法:
<sql:transaction [dataSource=”dataSource”]
[isolation=isolationLevel]>
<sql:query> and <sql:update> statements
</sql:transaction>

isolationLevel ::= "read_committed" | "read_uncommitted" | "repeatable_read" | "serializable"

示例:

param
功能:设置sql参数

语法:
<sql:param value=”value”/>

<sql:param>
parameter value
</sql:param>

示例:

* 函数库
格式:前缀 + 冒号 + 函数名

自定义函数的实现步骤:
1、创建Java类,在类中提供静态的方法(定义)

public static List findUsers() {
Group g1 = new Group("少年组");
Group g2 = new Group("中年组");
Group g3 = new Group("老年组");

User u1 = new User("zs", 10, g1);
User u2 = new User("lisi", 30, g2);
User u3 = new User("wangwu", 60, g3);

List userList = new ArrayList();
userList.add(u1);
userList.add(u2);
userList.add(u3);

return userList;
}


2、要到WEB-INF创建标签库描述符文件(.tld)(描述)
<?xml version="1.0" encoding="UTF-8" ?>

<taglib xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-jsptaglibrary_2_0.xsd"
version="2.0">

<description>my functions library</description>
<display-name>my functions</display-name>
<tlib-version>1.0</tlib-version>
<short-name>http://www.westaccp.com/functions</short-name>
<uri>http://www.westaccp.com/functions</uri>

<function>
<name>finduser</name>
<function-class>
com.westaccp.store.MyFounctions
</function-class>
<function-signature>
java.util.List findUsers()
</function-signature>
</function>

</taglib>

3、在Jsp页面中,通过taglib指令引入标签库并使用(使用)
<c:set var="userList" value="${my:finduser() }" scope="page" />

<select>
<c:forEach items="${userList}" var="u">
<option value="${u.age }">${u.group.name }</option>
</c:forEach>
</select>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值