SimpleTag——认识自定义标签
自定义标签
自定义标签的开发与应用步骤
- 编写完成标签功能的 Java 类(标签处理器)
- 编写标签库描述(tld)文件,在tld文件中对自定义中进行描述
- 在 JSP 页面中导入和使用自定义标签
①. 创建一个标签处理器类: 实现javax.servlet.jsp.tagext.SimpleTag接口.
package yang.mybatis.tag;
import javax.servlet.jsp.JspContext;
import javax.servlet.jsp.JspException;
import javax.servlet.jsp.tagext.JspFragment;
import javax.servlet.jsp.tagext.JspTag;
import java.io.IOException; /**
* Created by yangshijing on 2017/11/24 0024.
*/
public class HelloSimpleTag implements javax.servlet.jsp.tagext.SimpleTag{
@Override
public void doTag() throws JspException, IOException {
System.out.println("doTag");
} @Override
public void setParent(JspTag jspTag) {
System.out.println("setParent"); } @Override
public JspTag getParent() {
System.out.println("getParent");
return null;
} @Override
public void setJspContext(JspContext jspContext) {
System.out.println("setJspContext"); } @Override
public void setJspBody(JspFragment jspFragment) {
System.out.println("setJspBody"); }
}
②. 在 WEB-INF 文件夹下新建一个 .tld(标签库描述文件) 为扩展名的 xml 文件.
<?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">
<!--描述TLD 文件-->
<description>MyTag 1.0 core library</description>
<display-name>MyTag core</display-name>
<tlib-version>1.0</tlib-version>
<!--建议在Jsp页面上使用的标签的前缀-->
<short-name>myshortname</short-name>
<!-- 作为 tld 文件的 id, 用来唯一标识当前的 TLD 文件, 多个 tld 文件的 URI 不能重复. 通过 JSP 页面的 taglib 标签的 uri 属性来引用. -->
<uri>http://mycompany.com</uri> <!-- Invoke 'Generate' action to add tags or functions -->
<!--描述自定义的HelloSimpleTag 标签-->
<tag>
<!--标签名,在 JSP 页面上使用标签时的名字-->
<name>hello</name>
<!--标签所在的全类名-->
<tag-class>yang.mybatis.tag.HelloSimpleTag</tag-class>
<!--标签体的类型-->
<body-content>empty</body-content>
</tag>
</taglib>
③. 在 tld 文件中描述自定义的标签:
<!-- Invoke 'Generate' action to add tags or functions -->
<!--描述自定义的HelloSimpleTag 标签-->
<tag>
<!--标签名,在 JSP 页面上使用标签时的名字-->
<name>hello</name>
<!--标签所在的全类名-->
<tag-class>yang.mybatis.tag.HelloSimpleTag</tag-class>
<!--标签体的类型-->
<body-content>empty</body-content>
</tag>
④. 在 JSP 页面上使用自定义标签:
- 使用 taglib 指令导入标签库描述文件:
<%@taglib uri="http://mycompany.com" prefix="nchu" %>
- 使用自定义的标签:
<nchu:hello/>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%--导入标签库描述文件--%>
<%@taglib uri="http://mycompany.com" prefix="nchu" %>
<%@ taglib prefix="nchu" uri="http://mycompany.com" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<nchu:hello/>
</body>
</html>
⑤.从结果可以看出,使用自定义标签时,首先调用自定义SimpleTag实现类的SetJspContext()方法,然后调用doTag()方法
@Override
public void setJspContext(JspContext jspContext) {
System.out.println("setJspContext");
}
JspContext 是PageContext的父类,通过该方法传入的参数既是PageContext对象;可以通过PageContext对象获取jsp的隐含对象,进而在doTag()方法中对自定义标签实现功能。
在浏览器上输出Hello World
package yang.mybatis.tag;
import javax.servlet.jsp.JspContext;
import javax.servlet.jsp.JspException;
import javax.servlet.jsp.PageContext;
import javax.servlet.jsp.tagext.JspFragment;
import javax.servlet.jsp.tagext.JspTag;
import java.io.IOException; /**
* Created by yangshijing on 2017/11/24 0024.
*/
public class HelloSimpleTag implements javax.servlet.jsp.tagext.SimpleTag{
private PageContext pageContext;
@Override
public void doTag() throws JspException, IOException {
pageContext.getOut().print("Hello world!");
System.out.println("doTag");
} @Override
public void setParent(JspTag jspTag) {
System.out.println("setParent"); } @Override
public JspTag getParent() {
System.out.println("getParent");
return null;
} @Override
public void setJspContext(JspContext jspContext) {
pageContext = (PageContext) jspContext;
boolean b = jspContext instanceof PageContext;
System.out.println("setJspContext "+b); } @Override
public void setJspBody(JspFragment jspFragment) {
System.out.println("setJspBody"); }
}
SimpleTag——认识自定义标签的更多相关文章
- Servlet------>jsp自定义标签SimpleTag(jsp2.0以后的方法,1-5已经淘汰了)
自定义标签能做什么: 1.移除java代码 2.控制jsp页面某一部分是否执行 3.控制整个jsp是否执行 3.jsp内容重复输出 4.修改jsp内容输出 位置: TagDemo1.java pack ...
- [JSP]自定义标签库taglib
自定义标签的步骤 自定义标签的步骤大概有三步: 1.继承javax.servlet.jsp.tagext.*下提供的几个标签类,如Tag.TagSupport.BodyTagSupport.Simpl ...
- [Java] JSP笔记 - 自定义标签
自定义标签的创建步骤: 自定义标签的四大功能: 自定义标签的类结构: 在 1.0 中呢, 可以将 <body-content> 的值设置为 JSP, 2.0中则不允许在自定义标签体中出现j ...
- 12 自定义标签/JSTL标签库/web国际化/java web之设计模式和案例
EL应用 自定义一个标签,实现两个字符串的相加 1回顾 1.1servlet生命周期 init(ServletConfig) service ...
- EL函数以及自定义标签的应用
一.EL函数(调用普通类的静态方法) 编写步骤(自定义EL函数的编写步骤即自定义标签的编写步骤): ①编写一个普通的java类,提供一个静态方法,功能自定,例如下: package cn.wzbril ...
- JSTL 自定义标签
编写描述标签的tld文件,把这个文件放到web-inf/目录下,才能在jsp页面上调用自定义的标签 package test.yz; import java.io.IOException; impor ...
- JSP自定义标签/自定义标签打包
有这样一个业务需求: 当我们在编辑某个用户时,需要设置该用户的角色,在转到编辑页面时,就需要自动勾选上该用户已经选择的角色,如下图: 当我们点击编辑时,会查询用户详细信息,以及角色集合传到编辑页面. ...
- javaweb回顾第八篇如何创建自定义标签
前言:在javaweb开发中自定义标签的用处还是挺多的.今天和大家一起看自定义标签是如何实现的. 1:什么是标签 标签是一种XML元素,通过标签可以使JSP页面变得简介易用,而且标签具有很好的复用性. ...
- 自定义标签 与 JSTL(JSP Standard Tag Library)
1.自定义标签 [理解] [1]简介 > 在JSP2.0以后,在jsp页面中不建议使用脚本片段<% %>和JSP表达式<%= %> ...
随机推荐
- 【学习笔记】Manacher算法
本文部分图片来源 代码来源(代码是学姐哒.. 一.引入 Manacher算法是用来求最长回文子串的算法,时间复杂度O(n). 回文子串指的是''aacaa'',''noon'',这种正着反着读都一样的 ...
- Oracle恢复drop误删除的表和建用户操作
一.表的恢复 对误删的表,只要没有使用PURGE永久删除选项,那么从flash back区恢复回来希望是挺大的.一般步骤有: 1.从flash back里查询被删除的表 select * from r ...
- Rancher使用入门
http://tonybai.com/2016/04/14/an-introduction-about-rancher/
- eclipse配置hadoop2.7.2开发环境并本地跑起来
先安装并启动hadoop,怎么弄见上文http://www.cnblogs.com/wuxun1997/p/6847950.html.这里说下怎么设置IDE来开发hadoop代码和调试.首先要确保你本 ...
- 不常用的linux命令
不太常用的命令 vipw ##打开密码配置文件 dmesg ##补充说明:kernel会将开机信息存储在ring buffer中.您若是开机时来不及查看信息,可利用dme ...
- (转)使用PowerDesigner生成HTML功能
本文转载自:http://www.cnblogs.com/CowboyProgrammer/archive/2009/04/28/1445423.html 使用PowerDesigner设计数据库关系 ...
- DB2的安装
jiangxin@db01:~$ su – root #切换到root用户 密码: root@db01:~# uname -a #查看内核和操作系统信息 Linux db01 4.4.0-66-gen ...
- maven学习2
pom.xml文件中的内 1 <?xml version="1.0" encoding="UTF-8"?> 2 <project xmlns= ...
- ll | wc -l的陷阱
在平时我们可能经常使用ls和wc命令来统计某个文件夹下指定类型文件的个数.今天在使用的时候发现ls和ll出来的结果不一样. dwapp@pttest1:/home/dwapp/joe.wangh/te ...
- Three.js响应和移动物体
效果图 demo import './index.css'; // stats var stats; (function(){ stats = new Stats(); document.body.a ...