| |||||||
FRAMES NO FRAMES |
Render a button that does not cause an HTTP POST.
Encode Behavior
Render an HTML "input" element of type "button". The value of the component is rendered as the button text and the outcome of the component is used to determine the target URL which is activated by onclick. If "image" attribute is specified, render it as the value of the "src" attribute after passing it to the getResourceURL()
method of the ViewHandler
for this application, and passing the result through the encodeResourceURL()
method of the ExternalContext
.
If the component is not disabled, take the following actions.
Algorithm to obtain the url to which the user-agent should issue a GET request when clicked
Obtain the NavigationCase
that corresponds to the component instance for this Renderer
.
Obtain an instance of javax.faces.application.ConfigurableNavigationHandler
from the ViewHandler
. If no such instance can be obtained, write the "disabled" attribute on the button. Otherwise, let outcome be the result of calling getOutcome()
on the argument component, which must be an instance of UIOutcomeTarget
. If this result is null
, let outcome be the viewId of the current UIViewRoot
. Let navCase be the return from calling getNavigationCase()
on the ConfigurableNavigationHandler
, passing the current FacesContext
as the first argument, null
, as the second argument, and outcome as the third argument. If this returns null
, log an informative error which includes the component id, and write the "disabled" attribute on the component markup, with the value of true
. Otherwise obtain the encoded target URL using the following algorithm.
Algorithm to obtain the encoded target URL
Let params be the Map<String, List<String>>
to be passed to ViewHandler.getBookmarkableURL()
. Build this map up first from any child UIParameter
components. These children must be processed in the order in which they appear as children. If multiple children with the same name are encountered, their values must appear in the List<String>
in the Map
entry with the same name, and appear in the list in the same order as their child order.
Next, obtain any parameters included within the navigation case. Call getParameters()
on navCase. The result will be a Map<String, List<String>>
. If the result is non-null
and non-empty, iterate over the entries from the result Map
and, if no entry with the same name exists in params, set the value from the current entry as the value in the params Map
.
Let includeViewParams be the result of a logical OR of the results from calling isIncludeViewParams()
on the argument UIOutcomeTarget
component and calling isIncludeViewParams
on navCase.
Call getBookmarkableURL()
on the ViewHandler
, passing the current FacesContext
as the first argument, the return from calling getToViewId()
as the second argument, params as the third argument, and includeViewParams as the last argument.
The entire target URL string must be passed through a call to the encodeResourceURL()
method of the ExternalContext
. The name of the UIParameter
goes on the left hand side, and the value of the UIParameter
on the right hand side. The name and the value must be URLEncoded. Each UIParameter
instance is separeted by an ampersand, as dictated in the URL spec. The final encoded result will be written out to the onclick attribute of the button as "window.location.href = '
Tag Information | |
Tag Class | .OutcomeTargetButtonTag |
TagExtraInfo Class | None |
Body Content | JSP |
Display Name | None |
Attributes | ||||
Name | Required | Request-time | Type | Description |
id | false | true | java.lang.String | The component identifier for this component. This value must be unique within the closest parent component that is a naming container. |
includeViewParams | false | false | javax.el.ValueExpression
(must evaluate to java.lang.Boolean )
| Whether to include page parameters in the target URI. |
outcome | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| The logical outcome used to resolve a navigation case. |
rendered | false | false | javax.el.ValueExpression
(must evaluate to boolean )
| Flag indicating whether or not this component should be rendered (during Render Response Phase), or processed on any subsequent form submit. The default value for this property is true. |
value | false | false | javax.el.ValueExpression
(must evaluate to java.lang.Object )
| The current value of this component. |
accesskey | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Access key that, when pressed, transfers focus to this element. |
alt | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Alternate textual description of the element rendered by this component. |
dir | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Direction indication for text that does not inherit directionality. Valid values are "LTR" (left-to-right) and "RTL" (right-to-left). |
fragment | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| The identifier of the page fragment which should be brought into focus when the target page is rendered. The value of this attribute is appended to the end of target URL following a hash (#) mark. This notation is part of the standard URL syntax. |
image | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Absolute or relative URL of the image to be displayed for this button. If specified, this "input" element will be of type "image". Otherwise, it will be of the type specified by the "type" property with a label specified by the "value" property. Note that if the value of this attribute starts with "/", the rendered value for this attribute will be prefixed with the context-root for this application. |
lang | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Code describing the language used in the generated markup for this component. |
onblur | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Javascript code executed when this element loses focus. |
onclick | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Javascript code executed when a pointer button is clicked over this element. |
ondblclick | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Javascript code executed when a pointer button is double clicked over this element. |
onfocus | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Javascript code executed when this element receives focus. |
onkeydown | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Javascript code executed when a key is pressed down over this element. |
onkeypress | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Javascript code executed when a key is pressed and released over this element. |
onkeyup | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Javascript code executed when a key is released over this element. |
onmousedown | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Javascript code executed when a pointer button is pressed down over this element. |
onmousemove | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Javascript code executed when a pointer button is moved within this element. |
onmouseout | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Javascript code executed when a pointer button is moved away from this element. |
onmouseover | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Javascript code executed when a pointer button is moved onto this element. |
onmouseup | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Javascript code executed when a pointer button is released over this element. |
style | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| CSS style(s) to be applied when this component is rendered. |
styleClass | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Space-separated list of CSS style class(es) to be applied when this element is rendered. This value must be passed through as the "class" attribute on generated markup. |
tabindex | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Position of this element in the tabbing order for the current document. This value must be an integer between 0 and 32767. |
title | false | false | javax.el.ValueExpression
(must evaluate to java.lang.String )
| Advisory title information about markup elements generated for this component. |
binding | false | false | javax.el.ValueExpression
(must evaluate to javax.faces.component.UIComponent )
| The ValueExpression linking this component to a property in a backing bean |
Variables | ||||
No Variables Defined. |
| |||||||
FRAMES NO FRAMES |