我正在尝试做的事情似乎应该相对简单明了并且碰壁。
假设我有一个产品列表,该产品列表作为名称的request属性公开products。我们还说每个产品都有一个id字段,我还设置了一堆请求属性,selectedProduct_<product- id>以指示选择哪个。
products
id
selectedProduct_<product- id>
我知道有更好的方法来表示此信息,例如将所有选定的id放入a Map并进行检查,但让我们假设由于某种原因我无权使用该方法。
Map
因此,我想做的是products仅在selectedProduct_...为当前产品设置了属性的情况下进行迭代并发出一些标记。就像是:
selectedProduct_...
<c:forEach var="product" items="${products}"> <c:if test="${! empty selectedProduct_${product.id}}"> <div class="productId">${product.id}</div> </c:if> </c:forEach>
但是,当然这是行不通的,因为它死了${! empty selectedProduct_${product.id}}。
${! empty selectedProduct_${product.id}}
如果将product-id硬编码到表达式中,则将起作用,例如:
${! empty selectedProduct_17}
…假设“ 17”是有效的产品ID。显然,这是不切实际的,但希望它可以说明我正在尝试实现的目标。基本上我需要:
forEach
<c:set var="key" value="selectedProduct_${product.id}"/>
key
<% %>
使用纯JSP / JSTL是否可能?我知道我可以在其中运行一些Java代码<% %>来解决此问题,但是看起来这将是极其糟糕的形式。当然存在更优雅的解决方案?
您可以使用隐式对象:
有一些对象可以访问使用作用域对象中介绍的各种作用域变量。 pageScope:将页面范围的变量名称映射为其值 requestScope:将请求范围的变量名映射为其值 sessionScope:将会话范围的变量名映射为其值 applicationScope:将应用程序范围的变量名映射为其值 当表达式按名称引用这些对象之一时,将返回适当的对象而不是相应的属性。例如,即使现有的pageContext属性包含其他值,$ {pageContext}也会返回PageContext对象。
有一些对象可以访问使用作用域对象中介绍的各种作用域变量。
当表达式按名称引用这些对象之一时,将返回适当的对象而不是相应的属性。例如,即使现有的pageContext属性包含其他值,$ {pageContext}也会返回PageContext对象。
因此,例如:
<c:set var="selectedProductAttrName" value="selectedProduct_${product.id}"/> ${requestScope[selectedProductAttrName]}