引入

  1. <%@ taglib prefix="sys" tagdir="/WEB-INF/tags/sys" %>

这里注意/WEB-INF/tags/sys这里是一个目录,目录下有很多tag文件如下,调用sys:xxx,就会在当前目录下找xxx.tag的文件,必须有对应xxx.tag的文件与之对应

  1. <%@ tag language="java" pageEncoding="UTF-8"%>
  2. <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
  3. <%@ taglib prefix="fns" uri="/WEB-INF/tlds/fns.tld" %>
  4. <%@ attribute name="typeCode" type="java.lang.String" required="true" description="字典code"%>
  5. <%@ attribute name="defaultValue" type="java.lang.String" description="默认选中"%>
  6. <%@ attribute name="style" type="java.lang.String" description="默认选中"%>
  7. <%@ attribute name="cls" type="java.lang.String" description="默认选中"%>
  8. <%@ attribute name="name" type="java.lang.String" description="默认选中"%>
  9. <select style="${style}" class="${cls}" name="${name}" id="${name}" >
  10. <option value="" >请选择... </option>
  11. <c:if test="${not empty typeCode}">
  12. <c:forEach items="${fns:getDictList(typeCode)}" var='dict'>
  13. <option value='${dict.VALUE}' ${defaultValue==dict.VALUE?'selected':''}>${dict.TEXT}</option>
  14. </c:forEach>
  15. </c:if>
  16. </select>
attribute的属性介绍如下: 
1. name :这个attribute的名称. 
2. required : true/false, 是否必须的. 
3. rtexprvalue : true/false, 这个attribute可否使用EL表达式, 否则为纯文本. 
4. type : 设定这个attribute的类型, jsp容器会把结果自动转换成这个类.

如此,jsp名就是标签名,例如这个jsp叫 select.jsp,那么它的用法就是
<sys:select cls="formselect" name="MODULE_TYPE" typeCode="HOME_MODULE_TYPE" defaultValue="${record.MODULE_TYPE }" />

附上一个实际例子

treeselect.tag

  1. <%@ tag language="java" pageEncoding="UTF-8"%>
  2. <%@ include file="/WEB-INF/views/include/taglib.jsp"%>
  3. <%@ attribute name="id" type="java.lang.String" required="true" description="编号"%>
  4. <%@ attribute name="name" type="java.lang.String" required="true" description="隐藏域名称(ID)"%>
  5. <%@ attribute name="value" type="java.lang.String" required="true" description="隐藏域值(ID)"%>
  6. <%@ attribute name="labelName" type="java.lang.String" required="true" description="输入框名称(Name)"%>
  7. <%@ attribute name="labelValue" type="java.lang.String" required="true" description="输入框值(Name)"%>
  8. <%@ attribute name="title" type="java.lang.String" required="true" description="选择框标题"%>
  9. <%@ attribute name="url" type="java.lang.String" required="true" description="树结构数据地址"%>
  10. <%@ attribute name="checked" type="java.lang.Boolean" required="false" description="是否显示复选框,如果不需要返回父节点,请设置notAllowSelectParent为true"%>
  11. <%@ attribute name="extId" type="java.lang.String" required="false" description="排除掉的编号(不能选择的编号)"%>
  12. <%@ attribute name="isAll" type="java.lang.Boolean" required="false" description="是否列出全部数据,设置true则不进行数据权限过滤(目前仅对Office有效)"%>
  13. <%@ attribute name="notAllowSelectRoot" type="java.lang.Boolean" required="false" description="不允许选择根节点"%>
  14. <%@ attribute name="notAllowSelectParent" type="java.lang.Boolean" required="false" description="不允许选择父节点"%>
  15. <%@ attribute name="module" type="java.lang.String" required="false" description="过滤栏目模型(只显示指定模型,仅针对CMS的Category树)"%>
  16. <%@ attribute name="selectScopeModule" type="java.lang.Boolean" required="false" description="选择范围内的模型(控制不能选择公共模型,不能选择本栏目外的模型)(仅针对CMS的Category树)"%>
  17. <%@ attribute name="allowClear" type="java.lang.Boolean" required="false" description="是否允许清除"%>
  18. <%@ attribute name="allowInput" type="java.lang.Boolean" required="false" description="文本框可填写"%>
  19. <%@ attribute name="cssClass" type="java.lang.String" required="false" description="css样式"%>
  20. <%@ attribute name="cssStyle" type="java.lang.String" required="false" description="css样式"%>
  21. <%@ attribute name="smallBtn" type="java.lang.Boolean" required="false" description="缩小按钮显示"%>
  22. <%@ attribute name="hideBtn" type="java.lang.Boolean" required="false" description="是否显示按钮"%>
  23. <%@ attribute name="disabled" type="java.lang.String" required="false" description="是否限制选择,如果限制,设置为disabled"%>
  24. <%@ attribute name="dataMsgRequired" type="java.lang.String" required="false" description=""%>
  25. <div class="input-append">
  26. <input id="${id}Id" name="${name}" class="${cssClass}" type="hidden" value="${value}"/>
  27. <input id="${id}Name" name="${labelName}" ${allowInput?'':'readonly="readonly"'} type="text" value="${labelValue}" data-msg-required="${dataMsgRequired}"
  28. class="${cssClass}" style="${cssStyle}"/><a id="${id}Button" href="javascript:" class="btn ${disabled} ${hideBtn ? 'hide' : ''}" style="${smallBtn?'padding:4px 2px;':''}">&nbsp;<i class="icon-search"></i>&nbsp;</a>&nbsp;&nbsp;
  29. </div>
  30. <script type="text/javascript">
  31. $("#${id}Button, #${id}Name").click(function(){
  32. // 是否限制选择,如果限制,设置为disabled
  33. if ($("#${id}Button").hasClass("disabled")){
  34. return true;
  35. }
  36. // 正常打开
  37. top.$.jBox.open("iframe:${ctx}/tag/treeselect?url="+encodeURIComponent("${url}")+"&module=${module}&checked=${checked}&extId=${extId}&isAll=${isAll}", "选择${title}", 300, 420, {
  38. ajaxData:{selectIds: $("#${id}Id").val()},buttons:{"确定":"ok", ${allowClear?"\"清除\":\"clear\", ":""}"关闭":true}, submit:function(v, h, f){
  39. if (v=="ok"){
  40. var tree = h.find("iframe")[0].contentWindow.tree;//h.find("iframe").contents();
  41. var ids = [], names = [], nodes = [];
  42. if ("${checked}" == "true"){
  43. nodes = tree.getCheckedNodes(true);
  44. }else{
  45. nodes = tree.getSelectedNodes();
  46. }
  47. for(var i=0; i<nodes.length; i++) {//<c:if test="${checked && notAllowSelectParent}">
  48. if (nodes[i].isParent){
  49. continue; // 如果为复选框选择,则过滤掉父节点
  50. }//</c:if><c:if test="${notAllowSelectRoot}">
  51. if (nodes[i].level == 0){
  52. top.$.jBox.tip("不能选择根节点("+nodes[i].name+")请重新选择。");
  53. return false;
  54. }//</c:if><c:if test="${notAllowSelectParent}">
  55. if (nodes[i].isParent){
  56. top.$.jBox.tip("不能选择父节点("+nodes[i].name+")请重新选择。");
  57. return false;
  58. }//</c:if><c:if test="${not empty module && selectScopeModule}">
  59. if (nodes[i].module == ""){
  60. top.$.jBox.tip("不能选择公共模型("+nodes[i].name+")请重新选择。");
  61. return false;
  62. }else if (nodes[i].module != "${module}"){
  63. top.$.jBox.tip("不能选择当前栏目以外的栏目模型,请重新选择。");
  64. return false;
  65. }//</c:if>
  66. ids.push(nodes[i].id);
  67. names.push(nodes[i].name);//<c:if test="${!checked}">
  68. break; // 如果为非复选框选择,则返回第一个选择 </c:if>
  69. }
  70. $("#${id}Id").val(ids.join(",").replace(/u_/ig,""));
  71. $("#${id}Name").val(names.join(","));
  72. }//<c:if test="${allowClear}">
  73. else if (v=="clear"){
  74. $("#${id}Id").val("");
  75. $("#${id}Name").val("");
  76. }//</c:if>
  77. if(typeof ${id}TreeselectCallBack == 'function'){
  78. ${id}TreeselectCallBack(v, h, f);
  79. }
  80. }, loaded:function(h){
  81. $(".jbox-content", top.document).css("overflow-y","hidden");
  82. }
  83. });
  84. });
  85. </script>


jsp tag 直接文件实现的更多相关文章

  1. JSP TAG

    Jsp tag 能够灵活的将公共JSP代码模块化,类似<jsp:include page="./include.jsp"></jsp:include>等等. ...

  2. Servlet和JSP之标签文件学习

    在上一篇文章中介绍了自定义标签的用法,接下来介绍标签文件的用法啦. tag file指令 tag file简介 用tag file的方式,无需编写标签处理类和标签库描述文件,也可以自定义标签.tag ...

  3. Liferay JSP Tag Libraries介绍

    Liferay自带了很多标签库,这极大地提高了开发Liferay项目的效率. 下面让我们一起来探索吧. 什么是标签库? 什么是JSP标签? 什么是JSTL? 标签库由下面这几部分组成: Tag Lib ...

  4. jsp读取properties文件

    jsp读取properties文件 jsp中读取properties文件,并把值设到js变量中: mpi.properties文件内容: MerchantID=00000820 CustomerEMa ...

  5. Eclipse中jsp、js文件编辑时,卡死现象解决汇总

    使用Eclipse编辑jsp.js文件时,经常出现卡死现象,在网上百度了N次,经过N次优化调整后,卡死现象逐步好转,具体那个方法起到作用,不太好讲.将所有用过的方法罗列如下: 1.取消验证 windo ...

  6. Java使用JSP Tag Files & JSP EL Functions打造你自己的页面模板

    1. 简单说明:在JSP 2.0后, 你不再需要大刀阔斧地定义一堆TagSupport或BodyTagSupport, 使用JSP Tag Files技术可以实现功能强大的页面模板技术. 在这里抛砖引 ...

  7. Eclipse编辑jsp、js文件时,经常出现卡死现象解决汇总

    使用Eclipse编辑jsp.js文件时,经常出现卡死现象,在网上百度了N次,经过N次优化调整后,卡死现象逐步好转,具体那个方法起到作用,不太好讲.将所有用过的方法罗列如下: 1.取消验证 windo ...

  8. eclipse中web项目部署以后jsp的java文件找不到问题(Tomcat配置serverlocations)

    我的开发环境:eclipse kepler (4.3)+tomcat7.0.42. 在我想看eclipse中web项目jsp文件被tomcat转换成java以后的java源文件的位置,发现正常情况下的 ...

  9. JSP生成word文件

    1.jsp生成word文件,直接改动jsp格式: <%@ page contentType="application/vnd.ms-word;charset=GB2312"% ...

随机推荐

  1. [转]SSIS中OLE DB Source中如何执行Store Procedure 以得到源数据

    本文转自:http://www.cnblogs.com/michaelxu/archive/2009/10/16/1584284.html 有很多人喜欢在OLE DB Source中执行Store P ...

  2. (转)如何在maven环境中设置JVM参数

    有时候我们需要设定maven环境下的JVM参数,以便通过maven执行的命令或启动的系统能得到它们需要的参数设定.比如:当我们使用jetty:run启动jetty服务器时,在进行热部署时会经常发生:J ...

  3. Sublimetext 3 经常使用插件

    今天配了一下开发工具,事实上主要是想配置svn插件,可是后来查了下,发现sublimet的插件库还是蛮丰富的.顺手安了一些别的插件进去. 1,Svn插件安装的一些问题 首先ctrl+shift+p,打 ...

  4. 2013年八月GBin1月刊

    2013年八月GBin1月刊 推荐十款来自极客标签的超棒前端特效[第十二期] 本周,我们带来了极客社区推荐的10款前端特效,仍然是非常有趣的小动态效果的页面生成.喜欢的可以直接将我们的在线调试代码插入 ...

  5. angular中使用promise

    promise是一种用异步的方式处理值的方法,promise是对象,代表了一个函数最终可能的返回值或者抛出的异常,在与远程对象打交道时我们可以把他看作是远程对象的一个代理. 如果说是promise也是 ...

  6. 2019pycharm破解大法

    通过激活码激活Pycharm 1 先找到你的hosts文件: Windows电脑:c:\windows\system32\drivers\etc Linux/Mac电脑:/etc 2 编辑hosts文 ...

  7. php求斐波那契数列

    <?php function feibonaqi(){ //参数$num表示为第$num个数之前的所有斐波那契数列 $arr = array(); //定义一个空变量用来存放斐波那契数列的数组 ...

  8. Php取扩展名

    Php取扩展名 /** * 取扩展名 */ function getext($url){ $base = parse_url($url); $name = basename($base['path'] ...

  9. ES6 Promise catch

    getJSON方法返回一个 Promise 对象,如果该对象状态变为resolved,则会调用then方法指定的回调函数:如果异步操作抛出错误,状态就会变为rejected,就会调用catch方法指定 ...

  10. Vue 作用域插槽

    使用场景:复用子组件的slot,又可以使slot的内容不一样. <!DOCTYPE html> <html lang="zh"> <head> ...