Difference between returning null and "" from a JSF action

Brent C picture Brent C · Jan 5, 2012 · Viewed 15.2k times · Source

From what I understand, when a JSF action returns "" (empty String) the user stays on the current page but the view is refreshed. However, when the action returns null the user still stays on the current page but the old view is reused. My question is:

  1. Is the above statement correct (accurate)?
  2. If yes, then what are the implications of this? Specifically, what effect does using one versus the other have on data on the page (values in JSF UI components, or data stored in a request-scope bean in a DataTable, for example)?
  3. In what situations should one be used over the other?

Answer

BalusC picture BalusC · Jan 5, 2012

Is the above statement correct (accurate)?

Yes. Instead of returning null you can also just return void.


If yes, then what are the implications of this? Specifically, what effect does using one versus the other have on data on the page (values in JSF UI components, or data stored in a request-scope bean in a DataTable, for example)?

Nothing on request scoped beans. It has only effect on JSF2 view scoped beans. On returning null or void, the view scoped bean instance will be retained in the next request, else it will be recreated.


In what situations should one be used over the other?

If you want to retain the JSF2 view scoped bean in the subsequent request.

See also: