目前,我有一个Application,它由一个BasePage组成,它作为标题(面板),页脚(面板)和继承页面内容的中心。我遇到的问题是ResourceReferences(也许这甚至不是正确的方法)。我正在寻找一个解决方案,让我可以做到以下几点:
到目前为止,我已经阅读了几个示例,这些示例展示了如何为组件或应用程序级别范围打包资源,但似乎没有一个能够解决我正在寻求帮助的所有3个问题。至关重要的是,我不必将全局使用的图像(编辑图标,徽标等)复制到每个组件包中以进行引用,并且出于维护原因这些绑定可以在一个地方全局进行以便于参考,这将是很好的。更新
答案 0 :(得分:7)
自Wicket 1.4以来,这已经发生了重大变化。请参阅'Adding Javascript or CSS using a Resource' in Wicket's Wiki
要使图像和其他资源可以全局访问(特别是从CSS和JS文件中),请将它们安装在Applications的init()方法中:
mountSharedResource("/images/submit.jpg", new ResourceReference(MyComponent.class, "foo.jpg").getSharedResourceKey());
绝对不需要以任何方式复制资源。资源不必与组件本身位于相同的包中。在我们的应用程序中,我们将全局使用的资源放入专用包(比如com.example.myapp.images)并在其中放入一个类(例如ImagesScope.java) - 对于JS和CSS也是如此。
对于图像,您不需要ResourceReference
,因为您不需要在代码中呈现这些引用(org.apache.wicket.markup.html.image.Image除外)。对于JS和CSS使用
add(CSSPackageResource.getHeaderContribution(PanelOne.class, "PanelOne.css"));
顺便说一句,我是GitHub提供的little library called wicketstuff-merged-resources的作者。使用此库,您可以跳过应用程序的init()中的手动安装,而不是使用注释。
编辑:更新链接。不幸的是,wicketstuff wiki中的文档现在似乎已经消失了。虽然有some articles on our blog。