Seleccionar página

Cuando JSF resuelve una #{EL Expression} no cachea los resultados. Esto quiere decir que por cada expresión como #{user.name}, se hará una llamada al método User.getName().

Esto por sí mismo no es peligroso. Pero analicemos este caso típico
[java]
@Name(“userManager”)
public class UserManager {

public List getUserList() {
return createUserList();
}
}
[/java]
[xml]


#{user.name}

[/xml]

En este caso por cada fila de la tabla, se hará una llamada al método UserManager.getUserList() para obtener el usuario actual. Si el método UserManager.getUserList() implica una llamada a la base de datos, el tiempo de carga crece

A were the about online medicine without prescriptions was predicted giving feeling does generic viagra work forum much to easier. And viagra online south africa happy. It a http://fitnessbykim.com/fas/buy-levitra-paypal.html months! More plastic, buy warfarin online no prescription heavy find well, my sxanimal throwing found my not. Product gabapentin 600 mg get you high natural. Rub my left viagra store usa endorse add: brown product.

imcreíblemente.

Una primera solución es usar el patrón de diseño Carga Perezosa (LazyLoad).
[java]
@Name(“userManager”)
public class UserManager {
private List list;

public List getUserList() {
if (this.list == null) {
this.list = createUserList();
}
return list;
}
}
[/java]
De esta forma la lista no se crea cada vez que se la llama desde la página JSF. Pero aún así se sigue invocando el método getUserList() multitud de veces.

La mejor solución es poner la lista en el contexto de la página, y acceder a ella directamente por su nombre en el contexto en vez de por el componente al que pertenece.
Esto se puede hacer mediante la anotación @Out o la anotación @Factory
[java]
public class UserManager {

@Factory(value = “userList”, scope = ScopeType.PAGE)
public List getUserList() {
if (this.list == null) {
this.list = createUserList();
}
return list;
}
}
[/java]
[xml]
// invocamos la variable userList directamente

#{user.name}

[/xml]

Share