JSTL詳解(七)
9.7?Functions 標簽庫
稱呼
Functions
標簽庫為標簽庫,倒不如稱呼其為函數庫來得更容易理解些。因為
Functions
標簽庫并沒有提供傳統的標簽來為
JSP
頁面的
q???????? 長度函數: fn:length
q???????? 字符串處理函數: 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
函數正是為了解決這個問題而被
<%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>
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 ”之間仍然留有一個空格。
posted on 2007-01-18 15:19 nbt 閱讀(3235) 評論(1) 編輯 收藏 所屬分類: Servele&JSP和js