首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >ATG ForEach嵌套地图显示

ATG ForEach嵌套地图显示
EN

Stack Overflow用户
提问于 2015-01-02 15:53:37
回答 3查看 2.3K关注 0票数 0

我试图显示基于Map(String,Pojo)结构的嵌套地图数据。我尝试过各种不同的方法来使它显示出来,但是它不会识别pojo上的Map对象。

代码语言:javascript
运行
复制
            <dsp:droplet name="ForEach">
            <dsp:param name="array" bean="OrderInfo.sharedOfferInfo.parentDataMap"/>
            <dsp:oparam name="output">
            <dsp:getvalueof param="element.offersMap" var="offersMap" />
                <tr>
                    <td><p><dsp:valueof param="key" /> </p></td>
                    <dsp:droplet name="ForEach">
                        <dsp:param name="array" value="${offersMap}"/>
                        <dsp:oparam name="output">
                            <td><p><dsp:valueof param="element.description"/></p></td>
                            <td><p><dsp:valueof param="element.sku"/></p></td>
                        </dsp:oparam>
                    </dsp:droplet>
            </dsp:oparam>
            </dsp:droplet>

我对每件事都有更好的方法,所以不是这样的。嵌套的ForEach液滴根本不起作用吗?我在这里不知所措。

我已经尝试打印出"element.offersMap“对象中的内容,但是它只是打印一个空空间。如果我调试数据,所有数据都被正确填充,所以这也不是问题所在。我必须创建一个定制的液滴并返回特定的片段吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-02-03 11:28:35

尽管主要问题已经解决,但答案是嵌套的ForEach液滴问题。在处理嵌套ForEach时,尝试使用elementName属性而不是使用包含当前元素的元素。

元素(来自ORACLE ATG Docs)

每次呈现索引增量和输出参数时,设置为当前数组元素。

elementName

应该用于绑定到输出oparam范围的元素名称的可选参数。

代码语言:javascript
运行
复制
<dsp:droplet name="ForEach">
<dsp:param name="array" bean="OrderInfo.sharedOfferInfo.parentDataMap"/>
<dsp:param name="elementName" value="offers"/>
     <dsp:oparam name="output">
         <tr>
            <td><p><dsp:valueof param="key" /> </p></td>
            <dsp:droplet name="ForEach">
            <dsp:param name="array" param="offers.offersMap"/>
            <dsp:param name="elementName" value="offerMapValue"/>
                <dsp:oparam name="output">
                    <td><p><dsp:valueof param="offerMapValue.description"/></p></td>
                    <td><p><dsp:valueof param="offerMapValue.sku"/></p></td>
                </dsp:oparam>
           </dsp:droplet>
 </dsp:oparam>
</dsp:droplet>    
票数 1
EN

Stack Overflow用户

发布于 2015-01-03 22:09:14

我想parentDataMap是一张地图。如果要显示此地图的值,请尝试如下:

代码语言:javascript
运行
复制
<dsp:droplet name="ForEach">
        <dsp:param name="array" bean="OrderInfo.sharedOfferInfo.parentDataMap.values"/>

……

票数 0
EN

Stack Overflow用户

发布于 2015-01-08 21:42:54

啊,这个问题应该诚实地去掉。我只是用JSTL来解决这个问题。

父映射正确地返回了数据,问题是无论我做了什么,它都不会给我一个element.offersMap的值。

我使用JSTL实现了相同的功能,它运行得很好:

代码语言:javascript
运行
复制
<c:forEach items="${OrderInfo.sharedOfferInfo.parentDataMap}" var="entry">
    <tr><td colspan="5"><p><c:out value="${entry.key}"/></p></td></tr>
    <c:forEach items="${entry.value.offersMap}" var="entry2">
        <c:forEach items="${entry2.value}" var="entry3">
            <tr>
                <td></td>
                <td><p><c:out value="${entry2.key}" /></p></td>
                <td class="Text-Left"><p><c:out value="${entry3.description}" /></p></td>
                <td><p><c:out value="${entry3.sku}" /></p></td>
            </tr>
        </c:forEach>
    </c:forEach>
</c:forEach> 
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27744771

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档