Java Web基础入门第三十七讲 JSP技术——EL函数库
发布日期:2021-06-30 17:58:00 浏览次数:2 分类:技术文章

本文共 7875 字,大约阅读时间需要 26 分钟。

EL函数库介绍

由于在JSP页面中显示数据时,经常需要对显示的字符串进行处理,SUN公司针对于一些常见处理定义了一套EL函数库供开发者使用。这些EL函数在JSTL开发包中进行描述,因此在JSP页面中使用SUN公司的EL函数库,需要导入JSTL开发包,并在页面中导入EL函数库,如下所示:

在这里插入图片描述

EL函数使用范例

<%@page import="java.util.ArrayList"%><%@page import="java.util.List"%><%@ page language="java" contentType="text/html; charset=UTF-8"    pageEncoding="UTF-8"%><%--引入EL函数库 --%><%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %><%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
EL函数库中的方法使用范例

fn:toLowerCase函数使用范例:

<%-- fn:toLowerCase函数将一个字符串中包含的所有字符转换为小写形式,并返回转换后的字符串, 它接收一个字符串类型的参数。 注意:fn:toLowerCase("")的返回值为空字符串。 --%> <%-- fn:toLowerCase("Www.CNBLOGS.COM")的返回值为字符串“www.cnblogs.com” --%> fn:toLowerCase("Www.CNBLOGS.COM")的结果是:${fn:toLowerCase("Www.CNBLOGS.COM") }

fn:toUpperCase函数使用范例:

<%-- fn:toUpperCase函数将一个字符串中包含的所有字符转换为大写形式,并返回转换后的字符串, 它接收一个字符串类型的参数。 注意:fn:toUpperCase("")的返回值为空字符串。 --%> fn:toUpperCase("www.cnblogs.com")的结果是:${fn:toUpperCase("www.cnblogs.com") }

fn:trim函数使用范例:

<%-- fn:trim函数删除一个字符串的首尾的空格,并返回删除空格后的结果字符串, 它接收一个字符串类型的参数。 需要注意的是,fn:trim函数不能删除字符串中间位置的空格。 --%> fn:trim(" cnblogs.com ")的结果是:${fn:trim(" cnblogs.com ") }

fn:length函数使用范例:

<%-- fn:length函数返回一个集合或数组大小,或返回一个字符串中包含的字符的个数,返回值为int类型。 fn:length函数接收一个参数,这个参数可以是
标签的items属性支持的任何类型, 包括任意类型的数组、java.util.Collection、java.util.Iterator、java.util.Enumeration、java.util.Map等类的实例对象和字符串。 如果fn:length函数的参数为null或者是元素个数为0的集合或数组对象,则函数返回0;如果参数是空字符串,则函数返回0。 --%> <% request.setAttribute("arr", new String[5]); %> fn:length(arr)计算String[]的length的值是: ${fn:length(arr) } <%-- ${fn:length(${arr}) }:千万注意这种$符号不能嵌套 --%>
fn:length("cnblogs.com")计算字符串的长度是:${fn:length("cnblogs.com") }
<% List list = new ArrayList(); list.add("aa"); list.add("bb"); request.setAttribute("list", list); %> 利用fn:length函数遍历List集合:
${list[i] }

fn:split函数使用范例:

<%-- fn:split函数以指定字符串作为分隔符,将一个字符串分割成字符串数组并返回这个字符串数组。 fn:split函数接收两个字符串类型的参数,第一个参数表示要分割的字符串,第二个参数表示作为分隔符的字符串 --%> fn:split("www.cnblogs.com",".")[0]的结果是:${fn:split("www.cnblogs.com", ".")[0] }

fn:join函数使用范例:

<%-- fn:join函数以一个字符串作为分隔符,将一个字符串数组中的所有元素合并为一个字符串并返回合并后的结果字符串。 fn:join函数接收两个参数,第一个参数是要操作的字符串数组,第二个参数是作为分隔符的字符串。 如果fn:join函数的第二个参数是空字符串,则fn:join函数的返回值直接将元素连接起来。 --%> <% String[] strs = {"www", "iteye", "com"}; pageContext.setAttribute("strs", strs); %> <%-- fn:join(StringArray,".")返回字符串“www.iteye.com”--%> fn:join(StringArray,".")的结果是:${fn:join(strs, ".") }
<%-- fn:join(fn:split("www,iteye,com",","),".")的返回值为字符串“www.iteye.com”--%> fn:join(fn:split("www,iteye,com",","),".")的结果是:${fn:join(fn:split("www,iteye,com", ","), ".") }

fn:indexOf函数使用范例:

<%-- fn:indexOf函数返回指定字符串在一个字符串中第一次出现的索引值,返回值为int类型。 fn:indexOf函数接收两个字符串类型的参数,如果第一个参数字符串中包含第二个参数字符串, 那么,不管第二个参数字符串在第一个参数字符串中出现几次,fn:indexOf函数总是返回第一次出现的索引值; 如果第一个参数中不包含第二个参数,则fn:indexOf函数返回-1。 如果第二个参数为空字符串,则fn:indexOf函数总是返回0。 --%> fn:indexOf("www.iteye.com","eye")的返回值为:${fn:indexOf("www.iteye.com","eye") }

fn:contains函数使用范例:

<%-- fn:contains函数检测一个字符串中是否包含指定的字符串,返回值为布尔类型。 fn:contains函数在比较两个字符串是否相等时是大小写敏感的。 fn:contains函数接收两个字符串类型的参数,如果第一个参数字符串中包含第二个参数字符串,则fn:contains函数返回true,否则返回false。 如果第二个参数的值为空字符串,则fn:contains函数总是返回true。 实际上,fn:contains(string, substring)等价于fn:indexOf(string, substring) != -1 忽略大小的EL函数:fn:containsIgnoreCase --%> fn:contains("aaaaaabbcc","ab")的结果为:${fn:contains("aaaaaabbcc","ab") }

fn:startsWith函数和fn:endsWith函数使用范例:

<%-- fn:startsWith函数用于检测一个字符串是否是以指定字符串开始的,返回值为布尔类型。 fn:startsWith函数接收两个字符串类型的参数,如果第一个参数字符串以第二个参数字符串开始,则函数返回true,否则函数返回false。 如果第二个参数为空字符串,则fn:startsWith函数总是返回true。 与fn:startsWith函数对应的另一个EL函数为:fn:endsWith,用于检测一个字符串是否是以指定字符串结束的,返回值为布尔类型。 --%> fn:startsWith("www.iteye.com","iteye")的返回值为:${fn:startsWith("www.iteye.com","iteye") }
fn:endsWith("www.iteye.com","com")的返回值为:${fn:endsWith("www.iteye.com","com") }

fn:replace使用范例:

<%-- fn:replace函数将一个字符串中包含的指定子字符串替换为其它的指定字符串,并返回替换后的结果字符串。 fn:replace方法接收三个字符串类型的参数,第一个参数表示要操作的源字符串,第二个参数表示源字符串中要被替换的子字符串, 第三个参数表示要被替换成的字符串。 --%> fn:replace("www iteye com ", " ", ".")的返回值为字符串:${fn:replace("www iteye com ", " ", ".") }

fn:substring使用范例:

<%-- fn:substring函数用于截取一个字符串的子字符串并返回截取到的子字符串。 fn:substring函数接收三个参数,第一个参数是用于指定要操作的源字符串,第二个参数是用于指定截取子字符串开始的索引值,第三个参数是用于指定截取子字符串结束的索引值, 第二个参数和第三个参数都是int类型,其值都从0开始。 --%> fn:substring("www.it315.org", 4, 9) 的返回值为字符串:${fn:substring("www.it315.org", 4, 9) }

fn:substringAfter函数和fn:substringBefore函数使用范例:

<%-- fn:substringAfter函数用于截取并返回一个字符串中的指定子字符串第一次出现之后的子字符串。 fn:substringAfter函数接收两个字符串类型的参数,第一个参数表示要操作的源字符串,第二个参数表示指定的子字符串。 与之对应的EL函数为:fn:substringBefore。 --%> fn:substringAfter("www.it315.org",".")的返回值为字符串:${fn:substringAfter("www.it315.org",".") }
fn:substringBefore("www.it315.org",".")的返回值为字符串:${fn:substringBefore("www.it315.org",".") }

fn:escapeXml函数使用范例:

fn:escapeXml("<a href='www.cnblogs.com'>点点</a>")的结果是:${fn:escapeXml("
点点") }

运行结果如下:

在这里插入图片描述
还记得我们在中的二元运算符测试的例子吗?我们讲过二元运算符经常用在数据回显上,当时想要将一个人的爱好回显出来,因为当初我们学习到的知识无法解决,现在我们仔细地过了一遍JSTL的EL函数库,所以可以利用fn:contains函数和fn:join函数来解决这个遗留的问题了。代码如下:
在这里插入图片描述
还有一个问题,也是在这篇博客中的二元运算符测试的例子中,我们说过el表达式不支持字符串的连接,即+号运算符两边只能是数字不能是字符串。所以下面的代码是不能这样写的:

${user!=null ? 欢迎您:+ user.username : '' }

现在我们有这样的需求,那该怎么办呢?我们可以开发自定义函数,以调用Java类的方法。首先,编写MyEL类,其中添加对两个字符串相加的静态处理方法,如下:

package cn.liayun.demo;public class MyEL {
public static String filter(String message) {
if (message == null) return (null); char content[] = new char[message.length()]; message.getChars(0, message.length(), content, 0); StringBuilder result = new StringBuilder(content.length + 50); for (int i = 0; i < content.length; i++) {
switch (content[i]) {
case '<': result.append("<"); break; case '>': result.append(">"); break; case '&': result.append("&"); break; case '"': result.append("""); break; default: result.append(content[i]); } } return (result.toString()); } public static String add(String s1, String s2) {
return s1 + s2; }}

然后,在WEB-INF目录下编写标签库描述符(my.tld)文件,在my.tld文件中描述自定义函数。

A tag library exercising SimpleTag handlers.
1.0
SimpleTagLibrary
/my
filter
cn.liayun.demo.MyEL
java.lang.String filter( java.lang.String )
add
cn.liayun.demo.MyEL
java.lang.String add( java.lang.String, java.lang.String )

最后,在JSP页面中导入和使用自定义函数。

<%@page import="cn.liayun.domain.User"%><%@ page language="java" contentType="text/html; charset=UTF-8"    pageEncoding="UTF-8"%><%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %><%@ taglib uri="/my" prefix="my" %>
Insert title here <% User user = new User(); user.setUsername("张无忌"); session.setAttribute("user", user); %> ${user!=null ? my:add("欢迎您,", user.username) : "" }

以上jsp页面中使用到的cn.liayun.domain.User类的代码如下:

package cn.liayun.domain;public class User {
private String username; public String getUsername() {
return username; } public void setUsername(String username) {
this.username = username; } }

运行结果为:

在这里插入图片描述

转载地址:https://liayun.blog.csdn.net/article/details/52234296 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:Java Web基础入门第三十八讲 国际化(i18n)
下一篇:Java Web基础入门第三十六讲 JSP技术——EL表达式

发表评论

最新留言

关注你微信了!
[***.104.42.241]2024年04月05日 02时52分29秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章