利用TagSupport创建自定义标签实现网页左侧菜单


本次实验的项目结构图:




1. 创建自定义标签的处理类LeftMenu.java,需要继承TagSupport类。

package com.zhuomuniao.myproject.commons.taglib;

import javax.servlet.jsp.JspException;
import javax.servlet.jsp.JspTagException;
import javax.servlet.jsp.tagext.TagSupport;

@SuppressWarnings("serial")
public class LeftMenu extends TagSupport {
  
  private String title      = "";
  private String linkedMenu = "";
  private String linkedPath = "";

  //标签开始时调用的处理方法
	public int doStartTag() throws JspException {
    try {
      String[] menus = linkedMenu.split("/");
      String[] links = linkedPath.split("/");
      StringBuilder sp = new StringBuilder();
      sp.append("\n");
      sp.append("<table width=\"170\" class=\"menu\" >").append("\n");
      sp.append("  <tr>").append("\n");
      sp.append("    <td width=\"16\" height=\"25\"><img src=\"images/common/box_c_top_l.gif\" width=\"16\" height=\"25\"></td>").append("\n");
      sp.append("    <td background=\"images/common/box_c_top_bg.gif\"> </td>").append("\n");
      sp.append("    <td width=\"11\" height=\"22\"><img src=\"images/common/box_c_top_r.gif\" width=\"16\" height=\"25\"></td>").append("\n");
      sp.append("  </tr>").append("\n");
      sp.append("  <tr>").append("\n");
      sp.append("    <td valign=\"top\" background=\"images/common/box_l_bg.gif\"></td>").append("\n");
      sp.append("    <td valign=\"top\" bgcolor=\"#FFFFFF\">").append("\n");
      sp.append("      <table width=\"130\" class=\"menu\" >").append("\n");
      sp.append("        <tr>").append("\n");
      sp.append("          <td class=\"menu_title\"><span>"+title+"</span></td>").append("\n");
      sp.append("        </tr>").append("\n");
      sp.append("        <tr>").append("\n");
      sp.append("          <td height=\"2\" background=\"images/common/line_bg.gif\"></td>").append("\n");
      sp.append("        </tr>").append("\n");
      for(int i=0;i<menus.length;i++){
        String menu = menus[i];
        String link = links[i];
        sp.append("        <tr><td class=\"menu_list\"><span οnclick=\"doLeftLinked('"+link+"')\" οnmοuseοver=\"this.style.color='#ffa851'\" οnmοuseοut=\"this.style.color='#666666'\">"+menu+"</span></td></tr>").append("\n");
      }
      sp.append("        <tr>").append("\n");
      sp.append("          <td height=\"2\" background=\"images/common/line_bg.gif\"></td>").append("\n");
      sp.append("        </tr>").append("\n");
      sp.append("      </table>").append("\n");
      sp.append("    </td>").append("\n");
      sp.append("    <td valign=\"top\" background=\"images/common/box_r_bg.gif\"> </td>").append("\n");
      sp.append("  </tr>").append("\n");
      sp.append("  <tr>").append("\n");
      sp.append("    <td width=\"11\" height=\"22\" valign=\"middle\"><img src=\"images/common/box_c_bottom_l.gif\" width=\"16\" height=\"25\"></td>").append("\n");
      sp.append("    <td background=\"images/common/box_bottom_bg.gif\"> </td>").append("\n");
      sp.append("    <td width=\"11\" height=\"22\"><img src=\"images/common/box_c_bottom_r.gif\" width=\"16\" height=\"25\"></td>").append("\n");
      sp.append("  </tr>").append("\n");
      sp.append("</table>").append("\n");

      pageContext.getOut().println(sp.toString());

    } catch (Exception e) {
      throw new JspTagException(e.getMessage());  
    }
    return SKIP_BODY;	//跳过标签体的执行
  }

	
  public String getTitle() {
		return title;
	}
	public void setTitle(String title) {
		this.title = title;
	}
	public String getLinkedMenu() {
		return linkedMenu;
	}
	public void setLinkedMenu(String linkedMenu) {
		this.linkedMenu = linkedMenu;
	}
	public String getLinkedPath() {
		return linkedPath;
	}
	public void setLinkedPath(String linkedPath) {
		this.linkedPath = linkedPath;
	}

}

2. 创建标签库描述文件zhuomuniao.tld

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE taglib PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.2//EN"
                        "http://java.sun.com/dtd/web-jsptaglibrary_1_2.dtd">
<taglib>

	<!-- 标签库的版本号 -->
 	<tlib-version>1.0</tlib-version>
 	<!-- JSP的版本号 -->
 	<jsp-version>1.2</jsp-version>
 	<!-- 标签库的默认前缀 -->
 	<short-name>zhuomuniao</short-name>
 	<!-- 标签库的唯一访问标识符 -->
 	<uri>/zhuomuniao</uri>

 	<!-- 定义一个标签 -->
 	<tag>
  	<!-- 标签的名字 -->
  	<name>LeftMenu</name>
	<!-- 标签的处理类 -->
  	<tag-class>com.zhuomuniao.myproject.commons.taglib.LeftMenu</tag-class>
 	<!--标签体的内容:empty表示没有标签体,JSP表示标签体可以加入JSP程序代码,tagdependent表示标签体中的内容由标签自己处理 -->
  	<body-content>empty</body-content>
  
  	<!-- 定义标签的属性 -->
  	<attribute>
  	   	<!-- 属性名称 -->
	  	<name>title</name>
	  	<!-- 属性是否必需 -->
	  	<required>false</required>
	  	<!-- 属性值是否支持JSP表达式 -->
	  	<rtexprvalue>true</rtexprvalue>
		<type>java.lang.String</type>
  	</attribute>
  	<attribute>
   		<name>linkedMenu</name>
   		<rtexprvalue>true</rtexprvalue>
   		<type>java.lang.String</type>
  	</attribute>
  	<attribute>
   		<name>linkedPath</name>
   		<rtexprvalue>true</rtexprvalue>
   		<type>java.lang.String</type>
  	</attribute>
	</tag>
 
</taglib>

3. web.xml配置,在其中加入标签信息的配置

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" 
	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-app_2_5.xsd">
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>

  <jsp-config>
    <taglib>
      <taglib-uri>zhuomuniao</taglib-uri>
      <taglib-location>/WEB-INF/tld/zhuomuniao.tld</taglib-location>
    </taglib>
  </jsp-config>  
  
</web-app>


4. 创建一个使用自定义标签的JSP测试页面leftMenu.jsp

<%@ page language="java" pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib uri="zhuomuniao" prefix="zhuomuniao" %>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>My Tag</title>
		<meta http-equiv="pragma" content="no-cache">
		<meta http-equiv="cache-control" content="no-cache">
		<meta http-equiv="expires" content="0">    
		<link rel="stylesheet" type="text/css" href="css/leftMenu.css">
		<script type="text/javascript">
		function doLeftLinked(url){
			alert(url);
			//window.location.href=url;
		}
		</script>	
  </head>
  
  <body>
	<!-- LEFT MENU START -->
	<c:set var="title" value="菜单标题"/>
	<c:set var="menus" value="子菜单1/子菜单2/子菜单3/子菜单4"/>
	<c:set var="links" value="url1/url2/url3/url4"/>
	<zhuomuniao:LeftMenu title="${title}" linkedMenu="${menus}" linkedPath="${links}"/>
	<!-- LEFT MENU END -->
  </body>
</html>

用到的css样式

leftMenu.css

body {
	margin: 0px; 
	padding: 0px;
	border: 0px;
	overflow: auto; 
}

table.menu{
	margin: 0px;
	padding: 0px;
	border: 0px;
	border-collapse: collapse;		/*相邻边被合并*/
	border-spacing:0;
}

table.menu tr td{
	padding: 0px;
}

td.menu_title{ 
	line-height: 28px;
}

td.menu_title span{ 
	color: #033C6B;
	font-family: 宋体,TAHOMA;
	font-size: 16px;
	font-weight: bold; 
	padding-left: 5px;
}

td.menu_list{ 
	line-height: 28px;
}

td.menu_list span{ 
	color: #033C6B;
	font-family: 宋体,TAHOMA;
	font-size: 15px;
	font-weight:normal; 
	padding-left: 15px;
	cursor:pointer;
}


测试结果截图:


代码下载: http://download.csdn.net/detail/chuzhenbin/4159286



==============以上================



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值