9.7 Functions 标签库 称呼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以下是各个函数的用途和属性以及简单示例。 9.7.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 ”。 9.7.2 判断函数 fn:contains 函数 fn:contains函数用来判断源字符串是否包含子字符串。它包括string和substring两个参数,它们都是String类型,分布表示源字符串和子字符串。其返回结果为一个boolean类型的值。下面看一个示例。${fn:contains("ABC", "a")}<br> ${fn:contains("ABC", "A")}<br>前者返回“ false ”,后者返回“ true ”。 9.7.3 fn:containsIgnoreCase函数 fn:containsIgnoreCase函数与fn:contains函数的功能差不多,唯一的区别是fn:containsIgnoreCase函数对于子字符串的包含比较将忽略大小写。它与fn:contains函数相同,包括string和substring两个参数,并返回一个boolean类型的值。下面看一个示例。${fn:containsIgnoreCase("ABC", "a")}<br> ${fn:containsIgnoreCase("ABC", "A")}<br>前者和后者都会返回“ true ”。 9.7.4 词头判断函数 fn:startsWith 函数 fn:startsWith函数用来判断源字符串是否符合一连串的特定词头。它除了包含一个string参数外,还包含一个subffx参数,表示词头字符串,同样是String类型。该函数返回一个boolean类型的值。下面看一个示例。${fn:startsWith ("ABC", "ab")}<br> ${fn:startsWith ("ABC", "AB")}<br>前者返回“ false ”,后者返回“ true ”。 9.7.5 词尾判断函数 fn:endsWith 函数 fn:endsWith函数用来判断源字符串是否符合一连串的特定词尾。它与fn:startsWith函数相同,包括string和subffx两个参数,并返回一个boolean类型的值。下面看一个示例。${fn:endsWith("ABC", "bc")}<br> ${fn:endsWith("ABC", "BC")}<br>前者返回“ false ”,后者返回“ true ”。 9.7.6 字符实体转换函数 fn:escapeXml 函数 fn:escapeXml函数用于将所有特殊字符转化为字符实体码。它只包含一个string参数,返回一个String类型的值。9.7.8 字符匹配函数 fn:indexOf 函数 fn:indexOf函数用于取得子字符串与源字符串匹配的开始位置,若子字符串与源字符串中的内容没有匹配成功将返回“ -1 ”。它包括string和substring两个参数,返回结果为int类型。下面看一个示例。${fn:indexOf("ABCD","aBC")}<br> ${fn:indexOf("ABCD","BC")}<br>前者由于没有匹配成功,所以返回-1,后者匹配成功将返回位置的下标,为1。 9.7.9 分隔符函数 fn:join 函数 fn:join函数允许为一个字符串数组中的每一个字符串加上分隔符,并连接起来。它的参数、返回结果和描述如表9.25所示:表9.25 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.7.10 替换函数 fn:replace 函数 fn:replace函数允许为源字符串做替换的工作。它的参数、返回结果和描述如表9.26所示:表9.26 fn:replace函数 参数 | 描述 | inputString | 源字符串。其类型必须为String类型 | beforeSubstring | 指定被替换字符串。其类型必须为String类型 | afterSubstring | 指定替换字符串。其类型必须为String类型 | 返回结果 | 返回一个String类型的值 | 下面看一个示例。 ${fn:replace("ABC","A","B")}<br> 将“ ABC ”字符串替换为“ BBC ”,在“ ABC ”字符串中用“ B ”替换了“ A ”。 9.7.11 分隔符转换数组函数 fn:split 函数 fn:split函数用于将一组由分隔符分隔的字符串转换成字符串数组。它的参数、返回结果和描述如表9.27所示:表9.27 fn:split函数 参数 | 描述 | string | 源字符串。其类型必须为String类型 | delimiters | 指定分隔符。其类型必须为String类型 | 返回结果 | 返回一个String[]类型的值 | 下面看一个示例。 ${fn:split("A,B,C",",")}<br> 将“ A,B,C ”字符串转换为数组{A,B,C}。 9.7.12 字符串截取函数 fn:substring 函数 fn:substring函数用于截取字符串。它的参数、返回结果和描述如表9.28所示:表9.28 fn:substring函数 参数 | 描述 | string | 源字符串。其类型必须为String类型 | beginIndex | 指定起始下标(值从0开始)。其类型必须为int类型 | endIndex | 指定结束下标(值从0开始)。其类型必须为int类型 | 返回结果 | 返回一个String类型的值 | 下面看一个示例。 ${fn:substring("ABC","1","2")}<br> 截取结果为“ B ”。 9.7.14 起始到定位截取字符串函数 fn:substringBefore 函数 fn:substringBefore函数允许截取源字符从开始到某个字符串。它的参数和fn:substringAfter函数相同,不同的是substring表示的是结束字符串。下面看一个示例。${fn:substringBefore("ABCD","BC")}<br> 截取的结果为“ A ”。 9.7.15 小写转换函数 fn:toLowerCase 函数 fn:toLowerCase函数允许将源字符串中的字符全部转换成小写字符。它只有一个表示源字符串的参数string,函数返回一个String类型的值。下面看一个示例。${fn:toLowerCase("ABCD")}<br> 转换的结果为“ abcd ”。 9.7.16大写转换函数 fn:toUpperCase 函数 fn:toUpperCase函数允许将源字符串中的字符全部转换成大写字符。它与fn:toLowerCase函数相同,也只有一个String参数,并返回一个String类型的值。下面看一个示例。${fn:toUpperCase("abcd")}<br> 转换的结果为“ ABCD ”。 9.7.17空格删除函数 fn:trim 函数 fn:trim函数将删除源字符串中结尾部分的“空格”以产生一个新的字符串。它与fn:toLowerCase函数相同,只有一个String参数,并返回一个String类型的值。下面看一个示例。${fn:trim("AB C ")}D<br> 转换的结果为“ AB CD ”,注意,它将只删除词尾的空格而不是全部,因此“ B ”和“ C ”之间仍然留有一个空格。 |