http://www.myexception.cn/ai/1830837.html
关于EVAL_BODY_INCLUDE、SKIP_BODY、EVAL_BODY_AGAIN、EVAL_PAGE、SKIP_PAGE的区别探讨
最近在建立自定义标签并使用时,对于返回的值EVAL_BODY_INCLUDE、SKIP_BODY、EVAL_BODY_AGAIN、EVAL_PAGE、SKIP_PAGE分不太清楚,看网上的相关博客虽然讲得较为清晰,但是为了更加彻底地清楚他们的区别,动手写了一个实例,终于弄明白它们的区别,也是伤不起咯!
首先,建一个自定义标签的.tld文件,
<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE taglib PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.1//EN" "http://java.sun.com/j2ee/dtds/web-jsptaglibrary_1_1.dtd"> <taglib> <tlibversion>1.0</tlibversion> <jspversion>1.1</jspversion> <shortname>role</shortname> <uri>http://www.hhhh.com</uri> <info>Test Tags Library</info> <tag> <name>display</name> <tagclass>com.xxx.tag.TestTag</tagclass> <bodycontent>jsp</bodycontent> <info>just a test</info> <attribute> <name>type</name> <required>true</required> <rtexprvalue>true</rtexprvalue> </attribute> </tag> </taglib>
这个tld文件里面定义了一个名为display的tag,这个tag包含了一个名为type的属性。
在测试页面引用这个自定义标签。
<%@ taglib uri="/WEB-INF/tld/kkfun-test.tld" prefix="test"%> <test:display type="lala">热血高校</test:display>超级
所以,接下来开始定义相应的标签处理类:
public class TestTag extends BodyTagSupport { private String type; @Override public int doAfterBody() throws JspException { System.out.println("=========doAfterBody========="); return SKIP_BODY;//EVAL_BODY_AGAIN; } @Override public int doEndTag() throws JspException { System.out.println("========doEndTag========="); JspWriter out = this.pageContext.getOut(); try { out.println("Hello !!!!"); } catch (IOException e) { e.printStackTrace(); } return EVAL_PAGE;//SKIP_PAGE; } @Override public int doStartTag() throws JspException { System.out.println("======doStartTag========"); System.out.println("then you must call " + type.toUpperCase() + " first"); return SKIP_BODY;//EVAL_BODY_INCLUDE; } public String getType() { return type; } public void setType(String type) { this.type = type; }
需要注意的是,BodyTagSupport extends TagSupport,而我们一般来说用得较多的还是BodyTagSupport 。
整理如下:
1)标签处理类中extends BodyTagSupport ,一般来讲实现的三个方法是doStartTag,doAfterBody,doEndTag。
2)根据打印结果顺序:
======doStartTag======== then you must call LALA first ========doAfterBody========= ========doEndTag=========
可以看出标签处理类执行方法的一般顺序为:doStartTag()->doAfterBody()->doEndTag()
3)doStartTag()方法的合理返回值为EVAL_BODY_INCLUDE和SKIP_BODY
----------返回值为EVAL_BODY_INCLUDE时,表明执行标签体中间的内容,页面上的结果为:热血高校Hello !!!! 超级
----------返回值为SKIP_BODY时,表明不执行标签体中间的内容,页面上的结果为:Hello !!!! 超级
4)doAfterBody()方法的合理返回值为SKIP_BODY和EVAL_BODY_AGAIN
---------返回值为SKIP_BODY时,表示继续处理标签执行的下一步,页面上的结果为:热血高校Hello !!!! 超级
---------返回值为为EVAL_BODY_AGAIN时,表示会重复执行标签体中间的内容,页面上的结果为:热血高校热血高校热血高校Hello !!!! 超级
5)doEndTag()的合理返回值为EVAL_PAGE和SKIP_PAGE
---------返回值为EVAL_PAGE时,表示标签结束后继续执行页面上的内容,页面上的结果为:热血高校Hello !!!! 超级
---------返回值为为SKIP_PAGE时,表示不继续执行结束标签后的内容,页面上的结果为:热血高校Hello !!!!
巧妙的实际应用:比如一个管理系统的权限问题,当登录用户的用户类型符合某一集合时,就显示在自定义标签中的内容,此时doStartTag()返回EVAL_BODY_INCLUDE,表明他有权限访问标签体当中的内容;反之,当他不在这个集合中时,doStartTag()返回SKIP_BODY,表明不显示标签体中的内容,也就是没有权限访问。
小结:一般而言,doStartTag()返回SKIP_BODY,doAfterBodyTag()返回SKIP_BODY,doEndTag()返回EVAL_PAGE.
相关推荐
reset_jetbrains_eval_windows.rar
license_eval_halcon_progress_2022_03.dat
#include "stm32_eval_i2c_tsensor.h" #include "stm32_eval.h" #ifdef USE_STM32100E_EVAL #include "stm32100e_eval_lcd.h" #elif defined USE_STM3210E_EVAL #include "stm3210e_eval_lcd.h" #elif defined ...
license_eval_halcon_steady_2021_07
可以无限重置
license_eval_halcon_steady_2021_08
license_eval_halcon_steady_2021_08.dat
license_eval_halcon_steady_2022_03.dat
用darknet测试好的结果进行MAP值的计算程序,可以灵活使用。
官网下载的 uCOS-II Cortex-M0 Micrium_STM320518-EVAL_uCOS-II
包含TMC5160-EVAL_V31.SCH,TMC5160-EVAL_V31.PCB,TMC5160开发板
请注意,eval_tools 预计可与八度一起使用,从 MATLAB 运行时可能会出现错误 docker pull scaffrey/eval_tools_ap:dry_run docker run --rm -it \ -v /path/to/your/submission:/tools/data \ -v /path/to/save/...
AppScan_Std_9.0.3.5_Eval_Win.rar.P2P.DOWNLOAD
trec_eval_latest.tar trec_eval_latest.tar trec_eval_latest.tar
实时操作系统
官网下载的 uCOS-III Cortex-M4 Micrium_STM3240G-Eval_OS3
官网下载的 uCOS-II Cortex-M4 Micrium_STM3240G-Eval_OS2
能够进行绘制yolov3算法模型P-R曲线的脚本voc_eval_py3.py,在python3环境下运行。
Micrium_STM3240G-EVAL_OS2,官网未修改例程,STM32F4 ucosii hall 库,支持M4内核