public static enum RequestCycleSettings.RenderStrategy extends Enum<RequestCycleSettings.RenderStrategy>
Enum Constant and Description |
---|
ONE_PASS_RENDER
All logical parts of a request (the action and render part) are handled within the same
request.
|
REDIRECT_TO_BUFFER
All logical parts of a request (the action and render part) are handled within the same
request, but instead of streaming the render result to the browser directly, the result
is cached on the server.
|
REDIRECT_TO_RENDER
The render part of a request (opposed to the 'action part' which is either the
construction of a bookmarkable page or the execution of a IRequestListener handler) is
handled by a separate request by issuing a redirect request to the browser.
|
Modifier and Type | Method and Description |
---|---|
static RequestCycleSettings.RenderStrategy |
valueOf(String name)
Returns the enum constant of this type with the specified name.
|
static RequestCycleSettings.RenderStrategy[] |
values()
Returns an array containing the constants of this enum type, in
the order they are declared.
|
public static final RequestCycleSettings.RenderStrategy ONE_PASS_RENDER
This strategy is more efficient than the 'REDIRECT_TO_RENDER' strategy, and doesn't have some of the potential problems of it, it also does not solve the double submit problem. It is however the best option to use when you want to do sophisticated (non-sticky session) clustering.
public static final RequestCycleSettings.RenderStrategy REDIRECT_TO_BUFFER
public static final RequestCycleSettings.RenderStrategy REDIRECT_TO_RENDER
This pattern solves the 'refresh' problem. While it is a common feature of browsers to refresh/ reload a web page, this results in problems in many dynamic web applications. For example, when you have a link with an event handler that e.g. deletes a row from a list, you usually want to ignore refresh requests after that link is clicked on. By using this strategy, the refresh request only results in the re-rendering of the page without executing the event handler again.
Though it solves the refresh problem, it introduces potential problems, as the request that is logically one, are actually two separate request. Not only is this less efficient, but this also can mean that within the same request attachment/ detachment of models is done twice (in case you use models in the bookmarkable page constructors and IRequestListener handlers). If you use this strategy, you should be aware of this possibility, and should also be aware that for one logical request, actually two instances of RequestCycle are created and processed.
Also, even with this strategy set, it is ignored for instances of
BookmarkableListenerRequestHandler
,
because otherwise they wouldn't be bookmarkable.
public static RequestCycleSettings.RenderStrategy[] values()
for (RequestCycleSettings.RenderStrategy c : RequestCycleSettings.RenderStrategy.values()) System.out.println(c);
public static RequestCycleSettings.RenderStrategy valueOf(String name)
name
- the name of the enum constant to be returned.IllegalArgumentException
- if this enum type has no constant with the specified nameNullPointerException
- if the argument is nullCopyright © 2006–2022 Apache Software Foundation. All rights reserved.