开发者

jstl forToken with Nested HashMap in request Attribute

I have a HashMap (hshFields) of HashMaps (ecd_date, owned_by, etc..) with keys (label, size, etc..that I access as such:

<c:out value="${hshFields.ecd_date.label}" />
<c:out value="${hshFields.owned_by.label}" />
<c:out value="${hshFields.fnd_source.label}" />

(note: I must use JSTL and not EL)

the about spits out the a "label" of the field (maintained in an XML map) i.e.:

commitment_id = Commitment Id 
owned_by = Commitement Owner
fndsource = Funding Source

I'd like to now use a jstl forToken to loop over the nested HashMap. But I can not get it to work. Here is one of my attempts:

 <c:forTokens items="commitment_id, owned_by, fndsource" delims="," var="curField">
    The Field Label is: <c:out value="${hshFields.${curField}.label}" /> <br />
    The Field Sixze is: <c:out value="${hshFields.${curField}.size}" /> <br />
</c:forTokens>

Is this not working because Of incorrect syntax or hopefully not because I don't have EL capability??

EDIT OK based on skaffman's response below I have:

<c:forTokens items="owned_by, ecd_date, commitment_id" delims="," var="curField">
  Label for <c:out value="${curField}" /> : <c:out value="${hshFields[curField].label}" /><br></br>
</c:forTokens>

and the output is:

Label for owned_by : Commitment Owner
Label for ecd_date : 
Label for commitment_id : 

It seems to be working on开发者_运维知识库ly on the first token because if I use the following:

Label for owned_by : <c:out value="${hshFields.owned_by.label}" /> <br></br>
Label for ecd_date : <c:out value="${hshFields.ecd_date.label}" /> <br></br>
Label for commitment_id : <c:out value="${hshFields.commitment_id.label}" /> <br></br>

I get this output:

Label for owned_by : Commitment Owner
Label for ecd_date : Estimated Completion Date
Label for commitment_id : Commitment Number


Your syntax isn't quite right, it should be

<c:out value="${hshFields[curField].label}" />

rather than

<c:out value="${hshFields.${curField}.label}" />

Nested EL expressions like that isn't permitted.

updated: The reason it's only working for the first iteration in the loop is because you have spaces as well as commas in your items list, and the delims only handles the commas. So change the loop to

items="commitment_id,owned_by,fndsource"

rather than

items="commitment_id, owned_by, fndsource"

Otherwise, the spaces will form part of the individual loop values.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜