web-dev-qa-db-fra.com

Comment afficher toutes les valeurs enum possibles dans une liste déroulante avec Spring et Thymeleaf?

J'ai un objet domain qui a une propriété enum et je souhaite afficher une liste déroulante avec toutes les valeurs enum possibles dans le formulaire pour cet objet. Imaginez l'objet suivant:

public class Ticket {

  private Long id;

  private String title;

  private State state;

  // Getters & setters

  public static enum State {
    OPEN, IN_WORK, FINISHED
  }

}

Dans mon contrôleur, j'ai une méthode qui rend un formulaire pour cet objet:

@RequestMapping("/tickets/new")
public String showNewTicketForm(@ModelAttribute Ticket ticket) {
  return "tickets/new";
}

Le modèle ressemble à ceci:

<form th:action="@{/tickets}" method="post" th:object="${ticket}">
  <input type="text" th:field="*{title}" />
  <select></select>
</form>

Plus tard, il devrait être transformé en quelque chose comme ceci:

<form action="/tickets" method="post">
  <input type="text" name="title" />
  <select name="state">
    <option>OPEN</option>
    <option>IN_WORK</option>
    <option>FINISHED</option>
  </select>
</form>

Comment créer le tag de sélection? La valeur sélectionnée doit également être automatiquement mappée sur le ticket afin que je puisse faire quelque chose comme ceci dans le contrôleur:

@RequestMapping(value = "/tickets", method = RequestMethod.POST)
public String createTicket(@Valid Ticket ticket) {
  service.createTicket(ticket);

  return "redirect:/tickets";
}
22
stevecross

Vous pourriez faire:

<select>
    <option th:each="state : ${T(com.mypackage.Ticket.State).values()}"
            th:value="${state}"
            th:text="${state}">
    </option>
</select>
59
jchampemont

De plus, si vous souhaitez séparer le nom ordinal de énumération de la chaîne affichée dans l'interface graphique, ajoutez des propriétés supplémentaires, par exemple un displayName :

public static enum State {

    OPEN("open"),
    IN_WORK("in work"),
    FINISHED("finished");

    private final String displayName;

    State(String displayName) {
        this.displayName = displayName;
    }

    public String getDisplayName() {
        return displayName;
    }
}

Et dans le fichier html:

<select>
  <option th:each="state : ${T(com.mypackage.Ticket.State).values()}" th:value="${state}" th:text="${state.displayName}"></option>
</select>

Ceci présentera le displayName à l'utilisateur et vous permettra de changer silencieusement cette chaîne ultérieurement sans refactoriser le code. Vous pouvez ajouter plus de propriétés comme th: title this way.

18
fkurth

cela a fonctionné pour moi:

public enum RoleEnum {
SUPER_ADMIN("SUPER_ADMIN"),
RESTAURANTE_ADMIN("RESTAURANTE_ADMIN");

private final String roleCode;

private RoleEnum(String roleCode) {
    this.roleCode = roleCode;
}

}

<select class="form-control" id="val-skill" name="role_id">
    <option th:each="role : ${T(com.users.enumeration.RoleEnum).values()}" th:value="${role}" th:text="${role}"></option>
</select>
0