[应用篇]第六篇 JSTL之自定义函数标签库
在之前的JSTL的总结中已经对函数标签库进行了一些说明,在这里我再一次重新整理一下!
自带函数标签库介绍
引入该标签库的方法为:
<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
| 函数名 | 函数说明 | 使用举例 |
|---|---|---|
fn:contains |
判断字符串是否包含另外一个字符串 | <c:if test="${fn:contains(name, searchString)}"> |
fn:containsIgnoreCase |
判断字符串是否包含另外一个字符串(大小写无关) | <c:if test="${fn:containsIgnoreCase(name, searchString)}"> |
fn:endsWith |
判断字符串是否以另外字符串结束 | <c:if test="${fn:endsWith(filename, ".txt")}"> |
fn:escapeXml |
把一些字符转成XML表示,例如 <字符应该转为< |
${fn:escapeXml(param:info)} |
fn:indexOf |
子字符串在母字符串中出现的位置 | ${fn:indexOf(name, "-")} |
fn:join |
将数组中的数据联合成一个新字符串,并使用指定字符格开 | ${fn:join(array, ";")} |
fn:length |
获取字符串的长度,或者数组的大小 | ${fn:length(shoppingCart.products)} |
fn:replace |
替换 字符串中指定的字符 | ${fn:replace(text, "-", "")} |
fn:split |
把字符串按照指定字符切分 | ${fn:split(customerNames, ";")} |
fn:startsWith |
判断字符串是否以某个子串开始 | <c:if test="${fn:startsWith(product.id, "100-")}"> |
fn:substring |
截取子串 | ${fn:substring(zip, 6, -1)} |
fn:substringAfter |
获取从某个字符所在位置开始的子串 | ${fn:substringAfter(zip, "-")} |
fn:substringBefore |
获取从开始到某个字符所在位置的子串 | ${fn:substringBefore(zip, "-")} |
fn:toLowerCase |
转为小写 | ${fn.toLowerCase(product.name)} |
fn:toUpperCase |
转为大写 | ${fn.UpperCase(product.name)} |
fn:trim |
去除字符串前后的空格 | ${fn.trim(name)} |
解释
- 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 首尾的空格 ,并将其返回
自定义函数库
第一步 自定义类 和 方法(public +static)
package com.pangsir.ty;publicclassTestFunction{/**** 自定义类和方法 ,方法必须是public + static* @param name* @return*/publicstaticString toTest(String name){return"练习自定义函数, "+name;}}
注: toTest()必须是 public static 的。
第二步 编写自定义 tld 文件,将此自定义tld文件放在WEB-INF或者WEB-INF的任意子目录下
<?xml version="1.0" encoding="UTF-8"?><taglibxmlns="http://java.sun.com/xml/ns/j2ee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-jsptaglibrary_2_0.xsd"version="2.0"><!--该文件主要是受这个的影响:http://java.sun.com/xml/ns/j2ee/web-jsptaglibrary_2_0.xsd --><description>test own defined functions library</description><display-name>test functions</display-name><!-- 定义的版本 --><tlib-version>1.0</tlib-version><!--这个名字可以随便取,尽量与文件名相同,这样我们知道文件在哪儿 --><short-name>test</short-name><!-- 这个地址是随便取得。到时候jsp页面引入这个地址 --><uri>http://codemihong.com/functions</uri><!-- 定义函数 --><function><!-- 自定义函数名称(随意) --><name>testFunction</name><!-- 定义函数的类全名称 --><function-class>com.pangsir.ty.TestFunction</function-class><!--java.lang.String:返回值类型 toTest:类定义的函数名(形参的数据类型) --><function-signature>java.lang.String toTest(java.lang.String)</function-signature></function></taglib>
说明:
- 标签
<description>、<description-name>、<tlib-version>、<short-name>、<uri>内容随意,注意这里设置的uri后面jsp中要引入。 <function>标签中的<name>标签在JSP中要作为函数名调用,这里的名字可以和实际的函数名一致,也可以不一致,可认为是实际函数名的别名。<function-class>标签是 包名+类名 (自定义类)。<function-signature>是自定义函数的说明,如果是包装类型,需写完整路径;如果是基本数据类型,则不需要。如下又一示例所示:
<function><description>Returns the index withing a string of the first occurrence of a specified substring.</description><name>indexOf</name><function-class>org.apache.taglibs.standard.functions.Functions</function-class><function-signature>int indexOf(java.lang.String, java.lang.String)</function-signature><example>${fn:indexOf(name, "-")}</example></function>
补充说明:注册JSTL函数,若uri为/WEB-INF/xxx.tld,则无需再下面tomcat中注册
<!-- 注册JSTL函数 --><jsp-config><taglib><taglib-uri>http://codemihong.com/functions</taglib-uri><taglib-location>/WEB-INF/myfunctions.tld</taglib-location></taglib></jsp-config>
第三步 在要使用自定义函数库的JSP页面中引入
<%@ taglib prefix="hp" uri="http://codemihong.com/functions" %>
第四步 使用:${前缀 + 冒号 + 函数的别名 }
<body><h1>测试JSTL--自定义函数库</h1><spanstyle="color:#006600;"></span> ${hp:testFunction("人总是需要向前看的") }</body>
第五步 测试
[应用篇]第六篇 JSTL之自定义函数标签库的更多相关文章
- 自定义函数标签(JSTL)
创建自定义函数标签步骤: 1.创建类,并且方法只能是静态 public static void operation(calculator cal) 2.书写tld <taglib xmlns=& ...
- JSTL函数标签库 fn标签
JSTL函数标签库 fn标签 在使用jstl的函数标签库之前需要在页面中引入: <%@ taglib prefix="fn" uri="http://java.su ...
- 自定义JSP标签库及Properties使用
自定义JSP标签库及Properties使用 自定义JSP标签 自定义JSP标签技术是在JSP 1.1版本中才出现的,它支持用户在JSP文件中自定义标签,这样可以使JSP代码更加简洁. 这些可重用的标 ...
- JSTL,自定义一个标签的功能案例
1.自定义一个带有两个属性的标签<max>,用于计算并输出两个数的最大值: 2.自定义一个带有一个属性的标签<lxn:readFile src=“”>,用于输出指定文件的内容 ...
- JSTL解析——007——fmt标签库02
各位亲们,近期事情比较多,没更新,come on! 1.<fmt:bundle>/<fmt:message>/<fmt:param>资源国际化标签 java中使用R ...
- JSTL解析——005——core标签库04
直接入主题,标签讲解 1.<c:import>标签 JSP里面有<% file include="XX"%> 与<jsp:include>,JS ...
- JSTL解析——002——core标签库01
javaEE5之前的版本需要引用JSTL相关的jar包.tld文件等,JAEE5之后就不用这么麻烦了, 如果你的还是不能使用就去官网下载(jstl.jar和standard.jar)这两个jar包,将 ...
- JSP标准标签库(JSTL)--函数标签库 fn
和String的方法类似,就是对String的一种封装. No. 函数标签名称 描述 1 ${fn:contains()} 查询某字符串是否存在,区分大小写 2 ${fn:containsIgnore ...
- Java_jsp.jstl.Function函数标签库.记录
JSTL Functions标签库 本书第12章的12.3节(定义和使用EL函数)介绍了EL函数的创建和使用方法.在JSTL Functions标签库中提供了一组常用的EL函数,主要用于处理字符串,在 ...
随机推荐
- Spring Boot(七):Mybatis 多数据源最简解决方案
说起多数据源,一般都来解决那些问题呢,主从模式或者业务比较复杂需要连接不同的分库来支持业务.我们遇到的情况是后者,网上找了很多,大都是根据 Jpa 来做多数据源解决方案,要不就是老的 Spring 多 ...
- CSS快速入门-前端布局1(抽屉)
一.效果图 前面对CSS基础知识有了一定的了解,是时候开始实战了!以下我对抽屉(https://dig.chouti.com/)主页进行模拟布局. 官方网站效果图: 模拟网站图: 二.实现步骤 1.整 ...
- JavaScript快速入门-ECMAScript本地对象(Number)
Number 对象是原始数值的包装对象. 创建一个Number对象:var myNum=new Number(value); 注意: 1.参数 value 是要创建的 Number 对象的数值,或是要 ...
- jenkis +sonarqube 对后端代码静态扫描,钉钉群通知执行结果(记录)
代码提交,触发后端sonar测试,测试完成,jenkins触发依赖任务,执行python脚本,达到预期,调用上线任务模块,进行上线,达不到预期,钉钉群通知. 牵涉到配置: 1.配置sonar测试任务 ...
- Jenkins 构建运行java程序
我们将在Jenkins建立执行一个简单的 HelloWorld 应用程序,构建和运行Java程序.打开网址:http://localhost:8080/jenkins 第1步- 转到Jenkins 仪 ...
- unity学习路线_重新出发
入门级 1.先观看视频教程做一个小案例 官方英文:Unity - Learn – Modules 国内中文:Sike学院 基础级 1.你需要接触完整性的教程网站 Siki学院 Unity游戏开发从入门 ...
- muduo网络库学习笔记(三)TimerQueue定时器队列
目录 muduo网络库学习笔记(三)TimerQueue定时器队列 Linux中的时间函数 timerfd简单使用介绍 timerfd示例 muduo中对timerfd的封装 TimerQueue的结 ...
- 关于几个vcenter的合并心得!
由于最近公司领导觉得公司几个vcenter管理的不同网段IP,办公的时候操作不方便,故本人把几个vcenter上面的esxi主机合并到一个里面! 通过几次测试,发现最简单的方法就是直接用一台vcent ...
- 集美大学1414班软件工程个人作业2——个人作业2:APP案例分析
一.作业链接 个人作业2:APP案例分析 二.博文要求 通过分析你选中的产品,结合阅读<构建之法>,写一篇随笔,包含下述三个环节的所有要求. 第一部分 调研, 评测 下载软件并使用起来, ...
- MongoDB给数据库创建用户
一.先以非授权的模式启动MongoDB 非授权: linux/Mac : mongod -f /mongodb/etc/mongo.conf windows : mongod --config c: ...