JSF <h:message>標籤

它用於顯示特定組件的單個消息。您可以通過將該組件的id傳遞給for屬性來顯示您的自定義消息。

以下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>

JSF <h:graphicImage>標籤的屬性

標籤 描述
for 它是用於分配組件ID的強制性標籤,因為該消息是組成的。
errorClass 它用於將CSS樣式類應用於嚴重性類為“ERROR”的任何消息。
errorStyle 它用於將CSS樣式應用於嚴重性級別為“ERROR”的任何消息。
fatalClass 它用於將CSS樣式類應用於嚴重性級別為“FATAL”的任何消息。
FatalStyle 它用於將CSS樣式應用於嚴重性級別為“FATAL”的任何消息。
infoClass 它用於將CSS樣式類應用於嚴重性級別為“INFO”的任何消息。
InfoStyle 它用於將CSS樣式應用於嚴重性級別為“INFO”的任何消息。
tooltip 它用於將消息的詳細資訊部分顯示為工具提示。
warnClass 它用於將CSS樣式類應用於嚴重性類為“WARN”的任何消息。
warnStyle 它用於將CSS樣式應用於嚴重性級別為“WARN”的任何消息。

實例

檔: index.xhtml 中有如下代碼 -

<?xml version="1.0" encoding="UTF-8"?>
<!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"
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:f="http://java.sun.com/jsf/core"
      xmlns:ui="http://java.sun.com/jsf/facelets">

    <h:body>
    <h:form>
      <h:messages style="color:red;margin:8px;" />
      <br />
      <h:panelGrid columns="3">
        Enter your username :
        <h:inputText id="username" value="#{user.username}"
          size="20" required="true"
          label="UserName" >
          <f:validateLength minimum="5" maximum="10" />
        </h:inputText>

        <h:message for="username" style="color:red" />

        Enter your age :
        <h:inputText id="age" value="#{user.age}"
          size="20" required="true"
          label="Age" >
          <f:validateLongRange for="age" minimum="1" maximum="200" />
        </h:inputText>

        <h:message for="age" style="color:red" />

      </h:panelGrid>

      <h:commandButton value="Submit" action="result" />

    </h:form>

    </h:body>
</html>

檔: UserBean.java 中有如下代碼 -

package com.zaixian;


import java.io.Serializable;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;

@ManagedBean(name="user")
@SessionScoped
public class User implements Serializable{

  private static final long serialVersionUID = 1L;

  public String username;
  public int age;

  public String getUsername() {
    return username;
  }
  public void setUsername(String username) {
    this.username = username;
  }
  public int getAge() {
    return age;
  }
  public void setAge(int age) {
    this.age = age;
  }

}

以下是result.xhtml檔中的代碼 -

<?xml version="1.0" encoding="UTF-8"?>
<!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"
      xmlns:h="http://java.sun.com/jsf/html">
    <h:body>
    Username : #{user.username}
    <br />
    Age : #{user.age}
    </h:body>
</html>

運行專案

啟動Tomcat完成後,在流覽器地址欄中輸入以下URL。

http://localhost:8080/hjsf/index.xhtml

運行結果如下 -

未輸入值直接提交,結果如下 -

輸入值後提交,結果如下 -


上一篇: JSF <h:graphicImage>標籤 下一篇: JSF <f:ajax>標籤