- JSF 教程
- JSF - 首页
- JSF - 概述
- JSF - 环境设置
- JSF - 架构
- JSF - 生命周期
- JSF - 第一个应用程序
- JSF - 托管Bean
- JSF - 页面导航
- JSF - 基本标签
- JSF - Facelet 标签
- JSF - 转换器标签
- JSF - 验证器标签
- JSF - DataTable
- JSF - 复合组件
- JSF - Ajax
- JSF - 事件处理
- JSF - JDBC 集成
- JSF - Spring 集成
- JSF - 表达式语言
- JSF - 国际化
- JSF 有用资源
- JSF - 快速指南
- JSF - 有用资源
- JSF - 讨论
JSF - h:message
h:message 标签显示与 UI 元素对应的消息。
JSF 标签
<h:inputText id = "username" size = "20" label = "UserName" required = "true"> <f:validateLength for = "username" minimum = "5" maximum = "20" /> </h:inputText> <h:message for = "username" style = "color:red" />
渲染输出
如果输入的用户名超过 20 个字符。
<span style = "color:red">UserName: Validation Error: Length is greater than allowable maximum of '20'</span>
如果输入的用户名少于 5 个字符。
<span style = "color:red">UserName: Validation Error: Length is less than allowable minimum of '5'</span>
如果未输入用户名。
<span style = "color:red">UserName: Validation Error: Value is required</span>
标签属性
| 序号 | 属性和描述 |
|---|---|
| 1 | id 组件的标识符 |
| 2 | binding 对组件的引用,可以在支持 Bean 中使用 |
| 3 | rendered 布尔值;false 抑制渲染 |
| 4 | styleClass 级联样式表 (CSS) 类名称 |
| 5 | for 显示其消息的组件的 ID,仅适用于 h:message |
| 6 | errorClass 应用于错误消息的 CSS 类 |
| 7 | errorStyle 应用于错误消息的 CSS 样式 |
| 8 | fatalClass 应用于致命消息的 CSS 类 |
| 9 | fatalStyle 应用于致命消息的 CSS 样式 |
| 10 | globalOnly 仅显示全局消息的指令,仅适用于 h:messages。默认值:false |
| 11 | infoClass 应用于信息消息的 CSS 类 |
| 12 | infoStyle 应用于信息消息的 CSS 样式 |
| 13 | layout 消息布局的规范:表格或列表,仅适用于 h:messages |
| 14 | showDetail 一个布尔值,确定是否显示消息详细信息。h:messages 的默认值为 false,h:message 的默认值为 true |
| 15 | showSummary 一个布尔值,确定是否显示消息摘要。h:messages 的默认值为 true,h:message 的默认值为 false |
| 16 | tooltip 一个布尔值,确定是否在工具提示中呈现消息详细信息;仅当 showDetail 和 showSummary 为 true 时才呈现工具提示 |
| 17 | warnClass 警告消息的 CSS 类 |
| 18 | warnStyle 警告消息的 CSS 样式 |
| 19 | style 内联样式信息 |
| 20 | title 一个标题,用于辅助功能,描述一个元素。可视浏览器通常为标题的值创建工具提示 |
示例应用程序
让我们创建一个测试 JSF 应用程序来测试上述标签。
| 步骤 | 描述 |
|---|---|
| 1 | 在 com.tutorialspoint.test 包下创建一个名为 helloworld 的项目,如 JSF - 第一个应用程序 章节中所述。 |
| 2 | 修改 home.xhtml,如下所述。保持其余文件不变。 |
| 3 | 编译并运行应用程序以确保业务逻辑按要求工作。 |
| 4 | 最后,以 war 文件的形式构建应用程序并将其部署到 Apache Tomcat Web 服务器中。 |
| 5 | 使用适当的 URL 启动您的 Web 应用程序,如下面的最后一步所述。 |
home.xhtml
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns = "http://www.w3.org/1999/xhtml">
<head>
<title>JSF Tutorial!</title>
</head>
<body>
<h2>h:messages example</h2>
<hr />
<h:form>
<h:panelGrid id = "panel" columns = "3" border = "0" cellpadding = "10"
cellspacing = "1">
<h:outputLabel value = "Enter Username" />
<h:inputText id = "username" size = "20" label = "UserName"
required = "true">
<f:validateLength for = "username" minimum = "5" maximum = "20" />
</h:inputText>
<h:message for = "username" style = "color:red" />
<h:outputLabel value = "Enter Password" />
<h:inputSecret id = "password" size = "20" label = "Password"
required = "true" redisplay = "true" >
<f:validateLength for = "password" minimum = "5" maximum = "10" />
</h:inputSecret>
<h:message for = "password" style = "color:red" />
<h:commandButton id = "submit" value = "Submit" action = "result"/>
</h:panelGrid>
</h:form>
</body>
</html>
准备好所有更改后,让我们像在 JSF - 第一个应用程序章节中所做的那样编译并运行应用程序。如果应用程序一切正常,则会产生以下结果。