~~ $Id$ ~~ ~~ Licensed to the Apache Software Foundation (ASF) under one ~~ or more contributor license agreements. See the NOTICE file ~~ distributed with this work for additional information ~~ regarding copyright ownership. The ASF licenses this file ~~ to you under the Apache License, Version 2.0 (the ~~ "License"); you may not use this file except in compliance ~~ with the License. You may obtain a copy of the License at ~~ ~~ http://www.apache.org/licenses/LICENSE-2.0 ~~ ~~ Unless required by applicable law or agreed to in writing, ~~ software distributed under the License is distributed on an ~~ "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY ~~ KIND, either express or implied. See the License for the ~~ specific language governing permissions and limitations ~~ under the License. ~~ ----------- Integration with FreeMarker ----------- Integration with FreeMarker {{{http://freemarker.sourceforge.net/}FreeMarker}} is a templating framework that can be used as a replacement for JavaServer Pages (JSP). Tiles can be used with FreeMarker through the use of Tiles FreeMarker package. * Configuration To use FreeMarker together with Tiles * Add FreeMarker jars (tested with FreeMarker 2.3.15). * Add <<>> and <<>> files to your application * To access ".ftl" files from HTTP requests, add this piece of configuration in <<>> (the parameters can be modified as needed). ---------------------------------- freemarker org.apache.tiles.freemarker.servlet.TilesFreemarkerServlet TemplatePath / NoCache true ContentType text/html template_update_delay 0 default_encoding ISO-8859-1 number_format 0.########## 5 ---------------------------------- * To access ".ftl" files as attributes, register FreeMarkerAttributeRenderer this way (only available in a servlet environment): ---------------------------------- @Override protected void registerAttributeRenderers( BasicRendererFactory rendererFactory, TilesApplicationContext applicationContext, TilesRequestContextFactory contextFactory, TilesContainer container, AttributeEvaluator evaluator) { super.registerAttributeRenderers(rendererFactory, applicationContext, contextFactory, container, evaluator); FreeMarkerAttributeRenderer freemarkerRenderer = new FreeMarkerAttributeRenderer(); freemarkerRenderer.setApplicationContext(applicationContext); freemarkerRenderer.setEvaluator(evaluator); freemarkerRenderer.setRequestContextFactory(contextFactory); freemarkerRenderer.setParameter("TemplatePath", "/"); freemarkerRenderer.setParameter("NoCache", "true"); freemarkerRenderer.setParameter("ContentType", "text/html"); freemarkerRenderer.setParameter("template_update_delay", "0"); freemarkerRenderer.setParameter("default_encoding", "ISO-8859-1"); freemarkerRenderer.setParameter("number_format", "0.##########"); freemarkerRenderer.commit(); rendererFactory.registerRenderer("freemarker", freemarkerRenderer); } ---------------------------------- This way you can specify an attribute that is rendered directly using this syntax: ---------------------------------- ---------------------------------- * Usage in FreeMarker templates Tiles directives are available this way: ---------------------------------- <@tiles.nameOfDirective> Other stuff... ---------------------------------- For details about directives see the {{{../../apidocs/index.html}Javadocs}}.