jstl fn的常见函数的总结

来源:互联网 发布:武汉科瑞财富网络 编辑:程序博客网 时间:2024/05/22 08:07
URI: http://java.sun.com/jsp/jstl/functions标签库的下载地址


前缀:fn的解释
Functions的简称,在jsp2.0规范下出现的。fn标签库分为两类,大概有16个函数。


1、长度函数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)}  
根据后台的arrayList1的传递,即可利用fn:length获取它的长度。


2、判断函数fn:contains
fn:contains  函数用来判断源字符串是否包含子字符串。它包括  string  和  substring  两个参数,它们都是  String  类型,分布表示源字符串和子字符串。其返回结果为一个  boolean  类型的值。示例。 
${fn:contains("ABC", "a")}<br>  
${fn:contains("ABC", "A")}<br>  
前者返回“  false  ”,后者返回“  true  ”。


3、空格删除函数fn:trim
fn:trim  函数将删除源字符串中结尾部分的“空格”以产生一个新的字符串。它与  fn:toLowerCase  函数相同,只有一个  String  参数,并返回一个  String  类型的值。示例。 
转换的结果为“  AB CD  ”,注意,它将只删除词尾的空格而不是全部,因此返回的结果是“AB CD”。


4、大写转换函数 fn:toUpperCase 
fn:toUpperCase  函数允许将源字符串中的字符全部转换成大写字符。它与  fn:toLowerCase  函数相同,也只有一个  String  参数,并返回一个  String  类型的值。示例。 
${fn:toUpperCase("abcd")}<br>  
转换的结果为“  ABCD  ”。 


5、小写转换函数 fn:toLowerCase
fn:toLowerCase  函数允许将源字符串中的字符全部转换成小写字符。它只有一个表示源字符串的参数  string  ,函数返回一个  String  类型的值。示例。 
${fn:toLowerCase("ABCD")}<br>  
转换的结果为“  abcd  ”。 


6、起始到定位截取字符串函数 fn:substringBefore  
fn:substringBefore  函数允许截取源字符从开始到某个字符串。它的参数和  fn:substringAfter  函数相同,不同的是  substring  表示的是结束字符串。示例。 
${fn:substringBefore("ABCD","BC")}<br>  
截取的结果为“  A  ”。 


7、字符串截取函数 fn:substring 
fn:substring  函数用于截取字符串。它的参数、返回结果:fn:substring(string,beginIndex,endIndex) 函数 string 源字符串。其类型必须为  String  类型  beginIndex 指定起始下标(值从  0  开始)。其类型必须为  int  类型  endIndex 指定结束下标(值从  0  开始)。其类型必须为  int  类型  返回一个  String  类型的值。示例。 
${fn:substring("ABC","1","2")}<br>  
截取结果为“  B  ”。 


8、分隔符转换数组函数 fn:split 
fn:split  函数用于将一组由分隔符分隔的字符串转换成字符串数组。它的参数、返回结果:fn:split(resString,delimiters) 函数 resString   源字符串。其类型必须为  String  类型  delimiters   指定分隔符。其类型必须为  String  类型  返回一个  String[]  类型的值。示例。 
${fn:split("A,B,C",",")}<br>  
将“  A,B,C  ”字符串转换为数组  {A,B,C}  。 


9、替换函数 fn:replace 
 fn:replace(inputString,beforeString,afterString)  函数允许为源字符串做替换的工作。它的参数、返回结果:inputString   源字符串。其类型必须为  String  类型  
 beforeSubstring   指定被替换字符串。其类型必须为  String  类型afterSubstring   指定替换字符串。其类型必须为  String  类型返回一个  String  类型的值。 示例。 
${fn:replace("ABC","A","B")}<br>  
将“  ABC  ”字符串替换为“  BBC  ”,在“  ABC  ”字符串中用“  B  ”替换了“  A  ”。 


10、分隔符函数 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  ”。 


11、字符匹配函数 fn:indexOf 
fn:indexOf  函数用于取得子字符串与源字符串匹配的开始位置,若子字符串与源字符串中的内容没有匹配成功将返回“  -1  ”。它包括  string  和  substring  两个参数,返回结果为  int  类型。示例。 
${fn:indexOf("ABCD","aBC")}<br>
${fn:indexOf("ABCD","BC")}<br>
前者由于没匹配成功,所以返回  -1  ,后者匹配成功将返回位置的下标,为1(位置从0开始)。 


12、字符实体转换函数 fn:escapeXml 
 fn:escapeXml 函数用于将所有特殊字符转化为字符实体码。它只包含一个  string  参数,返回一个  String  类型的值。
${fn:escapeXml("<b>Hello,Word!</b>")}
那么在页面输出加粗的Hello,Word!


13、词尾判断函数 fn:endsWith 
 fn:endsWith  函数用来判断源字符串是否符合一连串的特定词尾。它与  fn:startsWith  函数相同,包括  string  和  subffx  两个参数,并返回一个  boolean  类型的值。示例。 
${fn:endsWith("ABC", "bc")}<br>  
${fn:endsWith("ABC", "BC")}<br>  
前者返回“  false  ”,后者返回“  true  ”。 


14、词头判断函数 fn:startsWith  
 fn:startsWith  函数用来判断源字符串是否符合一连串的特定词头。它除了包含一个  string  参数外,还包含一个  subffx  参数,表示词头字符串,同样是  String  类型。该函数返回一个  boolean  类型的值。示例。 
${fn:startsWith ("ABC", "ab")}<br>  
${fn:startsWith ("ABC", "AB")}<br>  
前者返回“  false  ”,后者返回“  true  ”。 


15、fn:containsIgnoreCase 
fn:containsIgnoreCase  函数与  fn:contains  函数的功能差不多,唯一的区别是  fn:containsIgnoreCase  函数对于子字符串的包含比较将忽略大小写。它与  fn:contains  函数相同,包括  string  和  substring  两个参数,并返回一个  boolean  类型的值。示例。 
${fn:containsIgnoreCase("ABC", "a")}<br>  
${fn:containsIgnoreCase("ABC", "A")}<br>  
前者和后者都会返回“  true  ”。 


16、判断函数 fn:contains 
 fn:contains  函数用来判断源字符串是否包含子字符串。它包括  string  和  substring  两个参数,它们都是  String  类型,分布表示源字符串和子字符串。其返回结果为一个  boolean  类型的值。示例。 
${fn:contains("ABC", "a")}<br>  
${fn:contains("ABC", "A")}<br>  
前者返回“  false  ”,后者返回“  true  ”。
0 0