使用JSP Documents(JSPX)有条件地在元素上设置属性

iai*_*gin 18 xhtml jsp jspx webforms

在HTML表单中,可以通过在其上定义"disabled"属性来禁用按钮,具有任何值:

<button name="btn1" disabled="disabled">Hello</button>
Run Code Online (Sandbox Code Playgroud)

如果要启用某个按钮,则该属性不应该存在,因为没有定义的值可以将disabled属性设置为启用按钮.

当我想在使用JSP文档(jspx)时启用/禁用按钮时,这会导致我出现问题.由于JSP文档必须是格式良好的XML文档,我无法看到有条件地包含此属性的任何方式,因为以下内容不合法:

<button name="btn1" <%= (isDisabled) ? "disabled" : "" %/> >Hello</button>
Run Code Online (Sandbox Code Playgroud)

虽然我可以使用JSTL if标签复制标签两次以获得所需的效果,但在我的特定情况下,我在按钮上声明了超过15个属性(AJAX的许多javascript事件处理程序属性),因此重复标记将使JSP非常凌乱.

如何在不牺牲JSP可读性的情况下解决这个问题?是否有任何自定义标记可以通过操作输出DOM将属性添加到父级?

ale*_*lex 10

我使用带有动态属性的自定义JSP标记.你这样使用它:

<util:element elementName="button" name="btn1" disabled="$(isDisabled ? 'disabled' : '')"/>
Run Code Online (Sandbox Code Playgroud)

基本上,此标记的作用是使用elementName生成XML元素,并将所有属性放在标记中,但跳过空标记.

标签本身很容易实现,我的实现只有44行.

  • 你可以发布这个代码吗?我认为这将非常有启发性. (3认同)

Ben*_*wee 8

您可以使用<jsp:text>标记来使用有效的XML解决此问题:

<jsp:text><![CDATA[<button name="btn1"]]></jsp:text>
    <c:if test="${isDisabled}"> disabled="disabled"</c:if>
    >
    Hello!
<jsp:text><![CDATA[</button>]]></jsp:text>
Run Code Online (Sandbox Code Playgroud)

这显然比其他一些解决方案更冗长.但它完全独立:不需要自定义标签.此外,它可以轻松扩展到您需要的任意数量的属性.


pag*_*rix 6

@alex使用三元运算符的绝佳解决方案.我添加了一些我的例子,感谢你,我只是更改了条件的结果,如果为true,写入属性,否则不写任何东西

填充列表并选择使用的值,避免c:if

<select id="selectLang" name="selectLang" >
<c:forEach var="language" items="${alLanguages}" >
    <option value="${language.id}" ${language.code == usedLanguage ? 'selected' : ''} >${language.description}</option>
</c:forEach>
Run Code Online (Sandbox Code Playgroud)

在开始时检查单选按钮以避免c:if:

<input type="radio" id="id0" value="0" name="radio" ${modelVar == 0 ? 'checked' : ''} />
<input type="radio" id="id1" value="1" name="radio" ${modelVar == 1 ? 'checked' : ''} />
<input type="radio" id="id2" value="2" name="radio" ${modelVar == 2 ? 'checked' : ''} />
Run Code Online (Sandbox Code Playgroud)