如何从应用程序显示模板

时间:2017-07-21 16:56:13

标签: liferay

在Liferay DXP中,我使用Asset Publisher Portlet显示Web内容结构条目列表(在这种情况下是工作人员。)当我创建Staff Member Web内容结构时,有必要创建一个Web内容模板到跟着它。

但是,我的网页内容模板目前只是一个空模板,因为我不知道如何从Asset Publisher portlet使用的应用程序显示模板访问它,以显示我的工作人员列表。

我的应用程序显示模板目前如下所示:

<#if entries?has_content>
    <div class="staff-members">
        <div class="container">
            <h3>Our staff</h3>
            <div class="row offs">
                <#list entries as curEntry>
                    <#assign docXml = saxReaderUtil.read(curEntry.getAssetRenderer().getArticle().getContent()) />
                    <#assign name  = docXml.valueOf("//dynamic-element[@name='name']/dynamic-content/text()") />
                    <#assign photo  = docXml.valueOf("//dynamic-element[@name='photo']/dynamic-content/text()") />
                    <#assign bio  = docXml.valueOf("//dynamic-element[@name='bio']/dynamic-content/node()") />
                    <div class="col-md-3 col-sm-6 wow fadeIn animated" data-wow-duration="2s" data-wow-delay="0.2s" style="visibility: visible; animation-duration: 2s; animation-delay: 0.2s; animation-name: fadeIn;">
                        <div class="thumbnail">
                            <img src="${photo}" alt="${name}">
                            <div class="caption">
                                <h5>
                                    <a href="#">${name}</a>
                                </h5>
                                <p>${bio}</p>
                            </div>
                        </div>
                    </div>
                </#list>
            </div>
        </div>
    </div>
</#if>

正如您所看到的,我需要使用额外的标记来包装工作人员标记块;这就是为什么我使用Asset Publisher来显示我的应用程序显示模板。

正如我所提到的,此设置需要向Liferay添加一个空的Web内容模板(对于Staff成员结构),这看起来很愚蠢。我想要做的是在Web Content模板中定义可重复标记,并参考ADT中的模板。像这样:

<#if entries?has_content>
    <div class="staff-members">
        <div class="container">
            <h3>Our staff</h3>
            <div class="row offs">
                <#list entries as curEntry>
                    <#assign docXml = saxReaderUtil.read(curEntry.getAssetRenderer().getArticle().getContent()) />
                    <#assign name  = docXml.valueOf("//dynamic-element[@name='name']/dynamic-content/text()") />
                    <#assign photo  = docXml.valueOf("//dynamic-element[@name='photo']/dynamic-content/text()") />
                    <#assign bio  = docXml.valueOf("//dynamic-element[@name='bio']/dynamic-content/node()") />

                     <!-- 
                          CALL WEB CONTENT TEMPLATE HERE PASSING IN DATA
                          FOR THIS PARTICULAR WEB CONTENT ITEM.
                      -->
                </#list>
            </div>
        </div>
    </div>
</#if>

如何实现这一目标?

2 个答案:

答案 0 :(得分:1)

在这种情况下,您描述了甚至不需要使用SAX提取数据。看看那个有效的例子:

<#assign journalArticleLocalService = serviceLocator.findService("com.liferay.journal.service.JournalArticleLocalService")>

<#if entries?has_content>
    <#list entries as curEntry>
        <#assign article = curEntry.getAssetRenderer().getArticle() />
        ${journalArticleLocalService.getArticleContent(article, article.getDDMTemplateKey(), "VIEW", locale, objectUtil("com.liferay.portal.kernel.portlet.PortletRequestModel", renderRequest, renderResponse), themeDisplay)}
    </#list>
</#if>

如您所见,我们使用了几个保留变量(serviceLocator和objectUtil),因此您必须在使用该代码段之前在服务器中激活它们。

我不是在DXP工作,而是Liferay 7社区,无论如何都应该工作。

答案 1 :(得分:1)

感谢@gonzalezalo,但我能够在其他地方找到一个不涉及特殊服务器配置的解决方案。

我在这里发帖,以防其他人正在寻找这个问题的答案。

如果我们使用Liferay的liferay_ui标记(调用asset-display模块)并将其传递给AssetRenderer以及我们要发布的文章({{ 1}}),然后Liferay将重新找到与内容相关的模板,用当前文章填充它并将其渲染回页面:

curEntry