`

JSTL中foreach与fn表达式的详细使用说明

 
阅读更多

在jstl中的fn标签也是我们在网页设计中经常要用到的很关键的标签,在使用的时候要先加上头

<%@ taglib uri=" http://java.sun.com/jsp/jstl/functions " prefix="fn"%>就可以使用fn标签了。

具体使用方法请参见下表:

函数

描述

fn:contains(string, substring)

如果参数string中包含参数substring,返回true

fn:containsIgnoreCase(string, substring)

如果参数string中包含参数substring(忽略大小写),返回true

fn:endsWith(string, suffix)

如果参数 string 以参数suffix结尾,返回true

fn:escapeXml(string)

将有特殊意义的XML (和HTML)转换为对应的XML character entity code,并返回

fn:indexOf(string, substring)

返回参数substring在参数string中第一次出现的位置

fn:join(array, separator)

将一个给定的数组array用给定的间隔符separator串在一起,组成一个新的字符串并返回。

fn:length(item)

返回参数item中包含元素的数量。参数Item类型是数组、collection或者String。如果是String类型,返回值是String中的字符数。

fn:replace(string, before, after)

返回一个String对象。用参数after字符串替换参数string中所有出现参数before字符串的地方,并返回替换后的结果

fn:split(string, separator)

返回一个数组,以参数separator 为分割符分割参数string,分割后的每一部分就是数组的一个元素

fn:startsWith(string, prefix)

如果参数string以参数prefix

开头,返回true

fn:substring(string, begin, end)

返回参数string部分字符串, 从参数begin开始到参数end位置,包括end位置的字符

fn:substringAfter(string, substring)

返回参数substring在参数string中后面的那一部分字符串

fn:substringBefore(string, substring)

返回参数substring在参数string中前面的那一部分字符串

fn:toLowerCase(string)

将参数string所有的字符变为小写,并将其返回

fn:toUpperCase(string)

将参数string所有的字符变为大写,并将其返回

fn:trim(string)

去除参数string 首尾的空格,并将其返回

称呼Functions标签库为标签库,倒不如称呼其为函数库来得更容易理解些。因为Functions标签库并没有提供传统的标签来为JSP页面的工作服务,而是被用于EL表达式语句中。在JSP2.0规范下出现的Functions标签库为EL表达式语句提供了许多更为有用的功能。Functions标签库分为两大类,共16个函数。

长度函数:fn:length

字符串处理函数:fn:contains、fn:containsIgnoreCase、fn:endsWith、fn:escapeXml、fn:indexOf、fn:join、fn:replace、fn:split、fn:startsWith、fn:substring、fn:substringAfter、fn:substringBefore、fn:toLowerCase、fn:toUpperCase、fn:trim

以下是各个函数的用途和属性以及简单示例。

1. 长度函数fn:length 函数

长 度函数fn:length 的出现有重要的意义。在JSTL1.0 中,有一个功能被忽略了,那就是对集合的长度取值。虽然 java.util.Collection 接口定义了size 方法,但是该方法不是一个标准的JavaBean 属性方法(没有get,set 方法),因 此,无法通过EL 表达式“${collection.size}” 来轻松取得。

fn:length 函数正是为了解决这个问题而被设计出来的。它的参数为input ,将计算通过该属性传入的对象长度。该对象应该为集合类型或String 类型。其返回结果是一个int 类型的值。下面看一个示例。

<%ArrayList arrayList1 = new ArrayList();

arrayList1.add("aa");

arrayList1.add("bb");

arrayList1.add("cc");

%>

<% request.getSession().setAttribute("arrayList1", arrayList1);%>

$ {fn:length(sessionScope.arrayList1)}

假设一个ArrayList 类型的实例“arrayList1” ,并为其添加三个字符串对象,使用fn:length 函数后就可以取得返回结果为“3”

2. 判断函数fn:contains 函数

fn:contains 函数用来判断源字符串是否包含子字符串。它包括stringsubstring 两个参数,它们都是String 类型,分布表示源字符串和子字符串。其返回结果为一个boolean 类型的值。下面看一个示例。

$ {fn:contains("ABC", "a")}<br>

$ {fn:contains("ABC", "A")}<br>

前者返回“false” ,后者返回“true”

3. fn:containsIgnoreCase 函数

fn:containsIgnoreCase 函数与fn:contains 函数的功能差不多,唯一的区别是fn:containsIgnoreCase 函数对于子字符串的包含比较将忽略大小写。它与 fn:contains 函数相同,包括stringsubstring 两个参数,并返回一个boolean 类型的值。下面看一个示例。

$ {fn:containsIgnoreCase("ABC", "a")}<br>

$ {fn:containsIgnoreCase("ABC", "A")}<br>

前者和后者都会返回“true”

4. 词头判断函数fn:startsWith 函数

fn:startsWith 函数用来判断源字符串是否符合一连串的特定词头。它除了包含一个string 参数外,还包含一个subffx 参数,表示词头字符串,同样是String 类型。该函数返回一个boolean 类型的值。下面看一个示例。

$ {fn:startsWith ("ABC", "ab")}<br>

$ {fn:startsWith ("ABC", "AB")}<br>

前者返回“false” ,后者返回“true”

5. 词尾判断函数fn:endsWith 函数

fn:endsWith 函数用来判断源字符串是否符合一连串的特定词尾。它与fn:startsWith 函数相同,包括stringsubffx 两个参数,并返回一个boolean 类型的值。下面看一个示例。

$ {fn:endsWith("ABC", "bc")}<br> $ {fn:endsWith("ABC", "BC")}<br>

前者返回“false” ,后者返回“true”

6. 字符实体转换函数fn:escapeXml 函数

fn:escapeXml 函数用于将所有特殊字符转化为字符实体码。它只包含一个string 参数,返回一个String 类型的值。

7. 字符匹配函数fn:indexOf 函数

fn:indexOf 函数用于取得子字符串与源字符串匹配的开始位置,若子字符串与源字符串中的内容没有匹配成功将返回“-1” 。它包括stringsubstring 两个参数,返回结果为int 类型。下面看一个示例。

$ {fn:indexOf("ABCD","aBC")}<br> $ {fn:indexOf("ABCD","BC")}<br>

前者由于没有匹配成功,所以返回-1 ,后者匹配成功将返回位置的下标,为1

8. 分隔符函数fn:join 函数

fn:join 函数允许为一个字符串数组中的每一个字符串加上分隔符,并连接起来。它的参数、返回结果和描述如表所示:

表 fn:join 函数

参数

描述

array

字符串数组。其类型必须为String[] 类型

separator

分隔符。其类型必须为String 类型

返回结果

返回一个String 类型的值

下面看一个示例。

<% String[] stringArray = {"a","b","c"}; %>

<% request.getSession().setAttribute("stringArray", stringArray);%>

$ {fn:join(sessionScope.stringArray,";")}<br>

定义数组并放置到Session 中,然后通过Session 得到该字符串数组,使用fn:join 函数并传入分隔符“;” ,得到的结果为“a;b;c”

9. 替换函数fn:replace 函数

fn:replace 函数允许为源字符串做替换的工作。它的参数、返回结果和描述如表所示:

fn:replace 函数

参数

描述

inputString

源字符串。其类型必须为String 类型

beforeSubstring

指定被替换字符串。其类型必须为String 类型

afterSubstring

指定替换字符串。其类型必须为String 类型

返回结果

返回一个String 类型的值

下面看一个示例。

$ {fn:replace("ABC","A","B")}<br>

“ABC” 字符串替换为“BBC” ,在“ABC” 字符串中用“B” 替换了“A”

10. 分隔符转换数组函数fn:split 函数

fn:split 函数用于将一组由分隔符分隔的字符串转换成字符串数组。它的参数、返回结果和描述如表所示:

fn:split 函数

参数

描述

string

源字符串。其类型必须为String 类型

delimiters

指定分隔符。其类型必须为String 类型

返回结果

返回一个String[] 类型的值

下面看一个示例。

$ {fn:split("A,B,C",",")}<br>

“A,B,C” 字符串转换为数组{A,B,C}

11. 字符串截取函数fn:substring 函数

fn:substring 函数用于截取字符串。它的参数、返回结果和描述如表所示:

fn:substring 函数

参数

描述

string

源字符串。其类型必须为String 类型

beginIndex

指定起始下标(值从0 开始)。其类型必须为int 类型

endIndex

指定结束下标(值从0 开始)。其类型必须为int 类型

返回结果

返回一个String 类型的值

下面看一个示例。

$ {fn:substring("ABC","1","2")}<br>

截取结果为“B”

12.起始到定位截取字符串函数 fn:substringBefore 函数

fn:substringBefore 函数允许截取源字符从开始到某个字符串。它的参数和 fn:substringAfter 函数相同,不同的是 substring 表示的是结束字符串。下面看一个示例。

$ {fn:substringBefore("ABCD","BC")}<br>

截取的结果为“ A ”。

13.小写转换函数 fn:toLowerCase 函数

fn:toLowerCase 函数允许将源字符串中的字符全部转换成小写字符。它只有一个表示源字符串的参数 string ,函数返回一个 String 类型的值。下面看一个示例。

$ {fn:toLowerCase("ABCD")}<br>

转换的结果为“ abcd ”。

14.大写转换函数 fn:toUpperCase 函数

fn:toUpperCase 函数允许将源字符串中的字符全部转换成大写字符。它与 fn:toLowerCase 函数相同,也只有一个 String 参数,并返回一个 String 类型的值。下面看一个示例。

$ {fn:toUpperCase("abcd")}<br>

转换的结果为“ ABCD ”。

15.空格删除函数 fn:trim 函数

fn:trim 函数将删除源字符串中结尾部分的“空格”以产生一个新的字符串。它与 fn:toLowerCase 函数相同,只有一个 String 参数,并返回一个 String 类型的值。下面看一个示例。

$ {fn:trim("AB C ")}D<br>

转换的结果为“ AB CD ”,注意,它将只删除词尾的空格而不是全部,因此“ B ”和“ C ”之间仍然留有一个空格。

 

示例

<%@ page contentType="text/html;charset=gbk"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn"%>
<html>
<head>
<title>这个是 JSTL的    测试</title>
</head>
<body>
<c:set var="str" value="stringStRiNg"/>
<c:set var="t" value="tr"/>
<c:out value="${str} = ${fn:length(str)}"/>
<c:out value="${fn:toLowerCase(str)}"/>
<c:out value="${fn:toUpperCase('   ')}"/>
<c:out value="${fn:toUpperCase('AbCdEfg')}"/><br>
<c:out value="${fn:substring('asdfefg',0,3)}"/><br>
<c:out value="${fn:substringAfter('asdf','s')}"/><Br>
<c:out value="${fn:substringBefore(str,'g')}"/><Br>
<c:out value="${fn:trim(' sd dew e ')}"/><Br>
<c:out value=" d sd dew e "/><Br>
<c:out value="${fn:replace(str,'ing','IN')}"/><Br>
</body>
</html>

 与forEach 绑定使用
<c:set var="naturesList" value="${fn:split('幽默,乐观,外向,内向',',')}"/>
<c:forEach var="nature" items="${naturesList}" varStatus="varStatus">
 <span><form:checkbox path="natures" value="${nature}"/><label for="natures<c:out value="${varStatus.index+1}"/>"><c:out value="${nature}"/></label></span>
</c:forEach>



  在el中嵌套el的使用
<c:set var="userList" value="${fn:split(userIds,',')}"/> 
						<c:forEach var="user" items="${userList}" varStatus="varStatus">  
							<c:out value="${user}"/>
						</c:forEach>  
 
 如上,userIds为后台传值过来的request参数。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics