using(ajax.),Using Ajax with Facelets

Using Ajax with Facelets

As mentioned in the previous section, JavaServer Faces technology supports Ajax by using

a built-in JavaScript resource library that is provided as part of the JavaServer

Faces core libraries. This built-in Ajax resource can be used in JavaServer Faces

web applications in one of the following ways:

By using the f:ajax tag along with another standard component in a Facelets application. This method adds Ajax functionality to any UI component without additional coding and configuration.

By using the JavaScript API method jsf.ajax.request() directly within the Facelets application. This method provides direct access to Ajax methods, and allows customized control of component behavior.

Using the f:ajax Tag

The f:ajax tag is a JavaServer Faces core tag that provides Ajax functionality

to any regular UI component when used in conjunction with that component. In

the following example, Ajax behavior is added to an input component by including

the f:ajax core tag:

In this example, although Ajax is enabled, the other attributes of the

f:ajax tag are not defined. If an event is not defined, the

default action for the component is performed. For the inputText component, when no event

attribute is specified, the default event is valueChange. Table 11-1 lists the attributes of the

f:ajax tag and their default actions.

Table 11-1 Attributes of the f:ajax TagName

Type

Description

disabled

javax.el.ValueExpression that evaluates to a Boolean

A Boolean

value that identifies the tag status. A value of true indicates that the

Ajax behavior should not be rendered. A value of false indicates that the

Ajax behavior should be rendered. The default value is false.

event

javax.el.ValueExpression that evaluates

to a String

A String that identifies the type of event to which the

Ajax action will apply. If specified, it must be one of the

events supported by the component. If not specified, the default event (the event that

triggers the Ajax request) is determined for the component. The default event is

action for javax.faces.component.ActionSource components and valueChange for javax.faces.component.EditableValueHolder components.

execute

javax.el.ValueExpression that evaluates to

an Object

A Collection that identifies a list of components to be executed on

the server. If a literal is specified, it must be a space-delimited

String of component identifiers and/or one of the keywords. If a ValueExpression is

specified, it must refer to a property that returns a Collection of String

objects. If not specified, the default value is @this.

immediate

javax.el.ValueExpression that evaluates to a

Boolean

A Boolean value that indicates whether inputs are to be processed early in

the lifecycle. If true, behavior events generated from this behavior are broadcast during

the Apply Request Values phase. Otherwise, the events will be broadcast during the

Invoke Applications phase.

listener

javax.el.MethodExpression

The name of the listener method that is called when

a javax.faces.event.AjaxBehaviorEvent has been broadcast for the listener.

onevent

javax.el.ValueExpression that evaluates to a

String

The name of the JavaScript function that handles UI events.

onerror

javax.el.ValueExpression that evaluates

to a String

The name of the JavaScript function that handles errors.

render

javax.el.ValueExpression that

evaluates to an Object

A Collection that identifies a list of components to be

rendered on the client. If a literal is specified, it must be

a space-delimited String of component identifiers and/or one of the keywords. If a

ValueExpression is specified, it must refer to a property that returns a Collection

of String objects. If not specified, the default value is @none.

The keywords listed in Table 11-2 can be used with the execute and render

attributes of the f:ajax tag.

Table 11-2 Execute and Render KeywordsKeyword

Description

@all

All component identifiers

@form

The form that encloses the component

@none

No component

identifiers

@this

The element that triggered the request

Note that when you use the f:ajax tag in a Facelets page, the

JavaScript resource library is loaded implicitly. This resource library can also be loaded

explicitly as described in Loading JavaScript as a Resource.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值