我将 Thymeleaf 与 Spring MVC 4 结合使用,但是当我要打印列表大小时遇到问题
<tr th:each="u : ${users}" th:id="${u.username}" class="odd gradeX"> <th></th> <td th:text="${u.username}"></td> <td th:text="${u.email}"></td> <td th:switch="${u.enabled}"> <span th:case="true" class="badge badge-primary">Acitf</span> <span th:case="false" class="badge badge-danger">Désactivée</span> <span th:case="*" class="badge badge-dark">Inconnue</span> </td> <td th:switch="${u.roles}"> <span th:case="ROLE_SUPER_ADMIN">Super ADmin</span> <span th:case="ROLE_MANGER">Manager</span> <span th:case="ROLE_SUPERVISEUR">Superviseur</span> <span th:case="ROLE_USER">User</span> <span th:case="*">Inconnue</span> </td> <td th:text="${#calendars.format(u.creationDate,'dd/MM/yyyy hh:mm')}"></td> <td th:text="${#calendars.format(u.lastLogin,'dd/MM/yyyy hh:mm')}"></td> ** <td th:text="${u.engines}"></td> <td th:text="${u.subordonnes}"></td> ** <td></td> </tr>
问题就在这里th:text="${u.engines}</td>。engines是我User实体中的ArrayList 。我试过了th:size,th:list但是没有用。
th:text="${u.engines}</td>
engines
User
th:size
th:list
谁能帮我
这是我的User实体:
@OneToMany(mappedBy = "superieur") @JsonIgnore private List<User> subordonnes = new ArrayList<User>(); @ManyToMany(fetch = FetchType.EAGER, cascade = CascadeType.ALL) @JoinTable(name = "USERS_ENGINES", joinColumns = @JoinColumn(name = "USER_ID"), inverseJoinColumns = @JoinColumn(name = "NUM_EQUIPMENT")) @JsonIgnore private List<Engine> engines = new ArrayList<Engine>();
和我的Controller方法:
@RequestMapping(value = {"/listeUsers"}) public ModelAndView userlistePage() { ModelAndView model = new ModelAndView(); User logedUser = (User) SecurityContextHolder.getContext().getAuthentication().getPrincipal(); List<User> users = new ArrayList<User>(); users = userService.findUserSub(logedUser); model.addObject("users", users); model.setViewName("utilisateur/list_users"); return model; }
尝试将实用程序方法用于org.thymeleaf.expression.Lists:
org.thymeleaf.expression.Lists
<td th:text="${#lists.size(u.engines)}">[Engine Size]</td>