如何在 Magnolia 应用程序中使用 FreeMarker 模板?
Posted
技术标签:
【中文标题】如何在 Magnolia 应用程序中使用 FreeMarker 模板?【英文标题】:How to use a FreeMarker template in a Magnolia App? 【发布时间】:2019-10-21 23:55:52 【问题描述】:我正在使用 Magnolia 5.4 并按照文档开发了一个应用程序: https://documentation.magnolia-cms.com/display/DOCS54/Apps
应用程序在 magnolia shell 中正确呈现。 打开应用程序会显示一条«Hello World» 消息,如文档中所述: https://documentation.magnolia-cms.com/display/DOCS54/Programming+an+app#Programminganapp-MainSubApp
我已经删除了不必要的代码,结果如下:
public class HelloWorldMainSubAppViewImpl implements HelloWorldMainSubAppView
private VerticalLayout layout = new VerticalLayout();
private Listener listener;
public HelloWorldMainSubAppViewImpl()
layout.setMargin(true);
layout.setSpacing(true);
layout.addComponent(new Label("Hello World!"));
@Override
public Component asVaadinComponent()
return layout;
我想使用 FreeMarker 模板来定义自定义视图,而不是使用 Label 组件。
阅读了文档后,我还没有弄清楚如何做到这一点。
【问题讨论】:
【参考方案1】:我在这里可能错了,但据我所知,Freemarker 仅用于创建模板,不幸的是仅限于它。 https://documentation.magnolia-cms.com/display/DOCS60/Template+scripts
另一方面,您想要做的是开发您的自定义应用程序,这里是一个如何做到这一点的示例。 https://documentation.magnolia-cms.com/display/DOCS54/My+first+content+app
此外,如果您有动力迁移到最新的 Magnolia 版本,您可以使用 Content Types 轻松定义您的自定义应用程序。
希望对你有帮助,
干杯,
【讨论】:
【参考方案2】:这是我的问题的解决方案,基于以前的工作。
这是«Custom App»中描述的«EmbeddedPageSubApp»方法
在导航的某处创建一个常规页面。
打开 Configuration 应用程序,转到 /modules/<APP_NAME>/apps/<APP_NAME>/subApps/main
并向 mainSubApp 添加一个 url 属性,其中包含指向先前创建的页面的绝对路径。
将类属性/modules/<APP_NAME>/apps/<APP_NAME>/subApps/main
的值更改为info.magnolia.ui.framework.app.embedded.EmbeddedPageSubAppDescriptor
将subAppClass
属性的值更改为info.magnolia.ui.framework.app.embedded.EmbeddedPageSubApp
如果您不希望该页面可见restrict 它在“超级用户”组/角色中的访问权限,以便只有管理员可以使用它。
这会将它与 iframe 绑定。您应该选择一个空白模板,因为嵌入页面的导航元素在应用程序中是可见的。
【讨论】:
以上是关于如何在 Magnolia 应用程序中使用 FreeMarker 模板?的主要内容,如果未能解决你的问题,请参考以下文章
如何在 Magnolia Blossom 中进行 AJAX 调用?