Javaweb EL自定義函數(shù)開發(fā)及代碼實例
1.什么是EL自定義函數(shù)
EL自定義函數(shù)是在EL表達式中調用的某個java類的靜態(tài)方法,這個靜態(tài)方法需在web應用程序中進行配置才可以被EL表達式調用。
EL自定義函數(shù)可以擴展EL表達式的功能,讓EL表達式完成普通java程序代碼所能完成的功能。
2.EL自定義函數(shù)開發(fā)步驟
編寫EL自定義函數(shù)映射的java類中的靜態(tài)方法:這個Java類必須帶有public修飾符,方法必須是這個類的帶有public修飾符的靜態(tài)方法;
編寫標簽庫描述文件(tld文件),在tld文件中描述自定義函數(shù);
在jsp頁面中導入和使用自定義函數(shù)。
3.示例代碼
實現(xiàn)的功能是連接兩個字符串。
編寫靜態(tài)方法,有public修飾符,且為靜態(tài)方法,elFunction.java
package com.javaweb.tag; public class elFunction { public static String concat(String str1,String str2){ return str1+str2; } }
編寫標簽庫描述文件,即tld文件,相關的自定義函數(shù)的描述在function標簽中,elFunction.tld
<?xml version="1.0" encoding="UTF-8"?> <taglib xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-jsptaglibrary_2_1.xsd" version="2.1"> <description>MyTag 1.1 core library</description> <display-name>MyTag core</display-name> <tlib-version>1.1</tlib-version> <short-name>c</short-name> <uri>http://java.www.com/jsp/jstl/core/elFunction</uri> <function> <name>concat</name> <function-class>com.javaweb.tag.elFunction</function-class> <function-signature>java.lang.String concat(java.lang.String,java.lang.String)</function-signature> </function> </taglib>
jsp文件中導入和使用自定義函數(shù)。
<%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1"%> <%@ taglib uri="http://java.www.com/jsp/jstl/core/elFunction" prefix="koala"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>" rel="external nofollow" > <title>My JSP 'elFunction.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css" rel="external nofollow" > --> </head> <body> ${koala:concat(param.name1,param.name2)} </body> </html>
運行后輸出結果為:
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Eclipse引用XSD實現(xiàn)XML配置文件提示標簽的方法
今天小編就為大家分享一篇關于Eclipse引用XSD實現(xiàn)XML配置文件提示標簽的方法,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03