JSF 支持将 URL 参数映射到 EL。也支持生成 GET 友好的 URL 链接。
视图参数可用于将 URL 中的参数映射到 EL。要做到这一点只需添加类似下面的代码:
假设我们通过 index.xhtml?name=jack 访问页面:
[list]
[*] GET 请求参数名为 name。
[*] 转换和验证如果成功,那么参数将会成功绑定到 #{user.name}。转换和验证可以像 h:inputText 那样添加内嵌的 f:converter 和 f:validator 标签。例如:
[/list]
可以使用 f:event 标签对请求参数进行预处理:
在这段代码中,定义了 #{user.process} 方法,用于页面初始化之前需要的处理。
也可以使用 h:link 和 h:button 来创建 GET 链接。
上面的代码生成的 HTML 是:
GET 请求参数也很容易设置:
在这段代码中,如果 #{user.name} 的值是 Jack,那么这段代码生成的 HTML 是:
同样,h:button 也可以设置输出:
这段代码生成的 HTML 是:
文章来源:[url]http://www.aptusource.org/2014/04/java-ee-7-jsf-http-get/[/url]
视图参数可用于将 URL 中的参数映射到 EL。要做到这一点只需添加类似下面的代码:
<f:metadata>
<f:viewParam name="name" value="#{user.name}"/>
</f:metadata>
假设我们通过 index.xhtml?name=jack 访问页面:
[list]
[*] GET 请求参数名为 name。
[*] 转换和验证如果成功,那么参数将会成功绑定到 #{user.name}。转换和验证可以像 h:inputText 那样添加内嵌的 f:converter 和 f:validator 标签。例如:
<f:metadata>
<f:viewParam name="name" value="#{user.name}">
<f:validateLength minimum="1" maximum="5"/>
</f:viewParam>
</f:metadata>
[/list]
可以使用 f:event 标签对请求参数进行预处理:
<f:metadata>
<f:viewParam name="name" value="#{user.name}">
<f:validateLength minimum="1" maximum="5"/>
</f:viewParam>
<f:event type="preRenderView" listener="#{user.process}"/>
</f:metadata>
在这段代码中,定义了 #{user.process} 方法,用于页面初始化之前需要的处理。
也可以使用 h:link 和 h:button 来创建 GET 链接。
<h:link value="Login" outcome="login"/>
上面的代码生成的 HTML 是:
<a href=".../faces/login.xhtml">Login</a>
GET 请求参数也很容易设置:
<h:link value="Login" outcome="login">
<f:param name="name" value="#{user.name}"/>
</h:link>
在这段代码中,如果 #{user.name} 的值是 Jack,那么这段代码生成的 HTML 是:
<a href=".../faces/login.xhtml?name=Jack">Login</a>
同样,h:button 也可以设置输出:
<h:button value="login"/>
这段代码生成的 HTML 是:
<input
type="button"
onclick="window.location.href='/JSFSample/faces/index.xhtml'; return false;"
value="login" />
文章来源:[url]http://www.aptusource.org/2014/04/java-ee-7-jsf-http-get/[/url]