Ответ 1
Вы могли бы сделать:
<select>
<option th:each="state : ${T(com.mypackage.Ticket.State).values()}"
th:value="${state}"
th:text="${state}">
</option>
</select>
У меня есть объект домена, у которого есть свойство enum, и я хочу отобразить выпадающий список со всеми возможными значениями перечисления в форме для этого объекта. Представьте себе следующий объект:
public class Ticket {
private Long id;
private String title;
private State state;
// Getters & setters
public static enum State {
OPEN, IN_WORK, FINISHED
}
}
В моем контроллере у меня есть метод, который отображает форму для этого объекта:
@RequestMapping("/tickets/new")
public String showNewTicketForm(@ModelAttribute Ticket ticket) {
return "tickets/new";
}
Шаблон выглядит следующим образом:
<form th:action="@{/tickets}" method="post" th:object="${ticket}">
<input type="text" th:field="*{title}" />
<select></select>
</form>
Позже он должен быть преобразован в нечто вроде этого:
<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>
Как создать тег select? Выбранное значение также должно быть автоматически сопоставлено с билетом, чтобы я мог сделать что-то вроде этого в контроллере:
@RequestMapping(value = "/tickets", method = RequestMethod.POST)
public String createTicket(@Valid Ticket ticket) {
service.createTicket(ticket);
return "redirect:/tickets";
}
Вы могли бы сделать:
<select>
<option th:each="state : ${T(com.mypackage.Ticket.State).values()}"
th:value="${state}"
th:text="${state}">
</option>
</select>
Кроме того, если вы хотите отделить имя имени enum от строки, отображаемой в графическом интерфейсе, добавьте дополнительные свойства, например 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;
}
}
И в html файле:
<select>
<option th:each="state : ${T(com.mypackage.Ticket.State).values()}" th:value="${state}" th:text="${state.displayName}"></option>
</select>
Это представит displayName пользователю и позволит вам без лишних изменений изменить эту строку позже, не рефакторинг кода. Вы можете добавить дополнительные свойства, такие как th: title таким образом.
это сработало для меня:
Java:
public enum RoleEnum {
SUPER_ADMIN("SUPER_ADMIN"),
RESTAURANTE_ADMIN("RESTAURANTE_ADMIN");
private final String roleCode;
private RoleEnum(String roleCode) {
this.roleCode = roleCode;
}
}
Thymeleaf:
<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>