当前位置:首页 > 开发 > 系统架构 > 架构 > 正文

JSTL自定义函数库的实现

发表于: 2010-07-16   作者:cuisuqiang   来源:转载   浏览:
摘要:  写一个Java类,该类包含要实现功能的静态方法 package com.golden.struts; public class MyFunctions { /** * @说明 方法必须是public static */ public static String sayHello(String name) { return "Hello "

 写一个Java类,该类包含要实现功能的静态方法

package com.golden.struts;
public class MyFunctions {
	/**
	 * @说明 方法必须是public static
	 */
	public static String sayHello(String name) {
		return "Hello " + name;
	}
}

 

提供TLD文件,该文件必须放置于WEB-INT下或WEB-INT任意子目录下

TLD文件的写法,可参考StrutsTLD文件

<?xml version="1.0" encoding="UTF-8" ?>
<taglib xmlns="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">
	<description>my functions library</description>
	<display-name>my functions</display-name>
	<tlib-version>1.0</tlib-version>
	<short-name>my</short-name>
	<uri>http://www.bjsxt.com/functions</uri>
	<function>
		<name>sayHello</name>
		<function-class>com.bjsxt.struts.MyFunctions</function-class>
		<function-signature>
			java.lang.String sayHello(java.lang.String)
		</function-signature>
	</function>
</taglib>

 

在页面引入

<%@ taglib prefix="my" uri="http://www.golden.com/functions"%>

 

使用

${my:sayHello(name) } 

 

备注:

描述,名称,版本,简写,uri,都是自定义,但不要与Struts的相关文件有冲突

方法的<name>是提供给JSP调用时使用的<function-class>对应上我们自定义的类

<function-signature>的写法一定要注意

返回值,方法名称,参数列表,如果返回时基本类型可以直接写int ,其他的要写上具体的类型名称如java.lang.Stringjava.lang.String[]java.lang.Object

JSTL自定义函数库的实现

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号