Whats the difference between JSF Custom Composite Components vs Custom Classic Components
Asked Answered
L

1

5

i want to build a custom JSF Component. Now i read some docs from oracle and saw a few code Examples. The problem is i am a bit confused:

It seems there are two ways to build a custom component with JSF 2.0+. As far as i understood since JSF 2.0 i can use these Composite Components to build my own component.

But do they have any disadvantages compared to the "Classical" Component ?

My Component will be rather complex do i loose anything (beside downwards compability) when i use Compisite Components ?

For example my Component will have some work todo in java, is this possible with Composite Components ?

Lilith answered 11/10, 2012 at 19:23 Comment(0)
V
10

A composite component is useful if you want to represent a bunch of closely related existing tags/components/HTML as a single and reuseable component by pure XML means.

A custom component would be the only way when there are no standard JSF tags/components available to achieve the requirement. E.g. <input type="file">, <input type="range">, etc. Note that such a custom component can in turn be used in a composite, whenever desireable.

Makes totally sense, right?

You can create a so-called "backing component" class extending UINamingContainer (or at least implementing NamingContainer) and bind it to the composite by <cc:interface componentType>. You can find several examples in my answers here.

Do however note that sometimes a composite component isn't suitable, you'd need to create a tag file instead. For example when you want to have a custom and reuseable <h:column>.

See also:

Venu answered 12/10, 2012 at 1:45 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.