Thymeleaf Preselected Select2选项

时间:2015-03-27 18:39:01

标签: java jquery-select2 thymeleaf

我正在尝试使用select2渲染具有多选列表的编辑页面。根据select2文档,只需设置一个选项selected="selected"即可,但我正在使用Java / Spring和Thymeleaf模板,所以它有点棘手。

<select id="programs" name="programs.id" style="min-width: 200px;" multiple="multiple">
    <option
            th:each="programs : ${programs}"
            th:value="${programs.id}"
            th:text="'['+${programs.category.name}+'] '+${programs.name}"
            th:selected="${#lists.contains(personProg,programs.id)}">
    </option>
</select>

programs.id是程序的ID,personProg是与人员ID相关联的程序列表,因此在列表中预先选择。

这个编译并加载正常,但没有选择任何选项。没有HTML或任何东西,我已经看了几个问题,注意到#lists.contains()方法。我看到它不适用于th:field属性,但我也没有。

Java供参考:

@RequestMapping(value="edit", method=RequestMethod.GET)
public String Edit(Model model, @RequestParam(value="userID") long id) {
    Person person = repo.findById(id);
    model.addAttribute("person", person);
    model.addAttribute("users", repo.findByOrderByLastnameAsc());
    model.addAttribute("programs", progRepo.findByOrderByIdAsc());
    model.addAttribute("personProg", personProgRepo.findByPersonid(person.getID()));
    for (PersonPrograms x : personProgRepo.findByPersonid(person.getID())) {
        System.out.println(x.getProgramid());
    }
    return "edit";
}

java控制台中的输出:

69
1
2
3
66
6
37
59
58

我在这里做错了什么?

1 个答案:

答案 0 :(得分:0)

发送的模型属性是personProg列表,而不是您想要的ID列表。制作一个列表,并通过ID列表而不是对象列表发送。

List<Integer> programIdList = new ArrayList<Integer>();
for (PersonPrograms x : personProgRepo.findByPersonid(person.getID())) {
   programIdList.add(x.getProgramid());
}
model.addAttribute("personProg", programIdList.toString());