В моем контроллере я устанавливаю хэш-карту

@ModelAttribute("clientImpMap")
public Map<String,String> populateClientImpMap() throws MalformedURLException, IOException 
{

    Map<String,String> clientImpMap = new HashMap<String,String> ();
    clientImpMap.put("1","High");
    clientImpMap.put("2","Low");
    return clientImpMap;
}

Теперь я хочу заполнить эту хэш-карту с помощью тегов Thymeleaf. Как это сделать? Используя основные теги Spring-mvc, я могу это сделать

<td>Client Importance :</td>
    <td><form:select path="personBean.clientImpRef">
            <form:option value="NONE" label="--- Select ---" />
            <form:options items="${clientImpMap}"  />
        </form:select></td>
    <td><form:errors path="personBean.clientImpRef" cssClass="error" /></td>
</tr>

Что эквивалентно этому в тимелисте?

3
Ayan Biswas 2 Июн 2014 в 13:50

2 ответа

Лучший ответ

Следующий код соответствует jsp с тегами spring, которые вы разместили в своем вопросе.

<form action="your-controller-mapping" th:object="${personBean}">
   <select th:field="*{clientImpRef}">
      <option value="NONE">----Select----</option>
      <option th:each="entry : ${clientImpMap.entrySet()}" th:value="${entry.key}" th:text="${entry.value}">
        This will be replaced - is only used for natural templating
      </option>
   </select>
</form>
12
geoand 2 Июн 2014 в 10:32

Вот пример кода и ссылка

th:each="item : ${items}" th:text="${item.description}"

Thymeleaf для каждого варианта для выбора и аналогичных сценариев

<ul>
  <li th:each="item : ${items}" th:text="${item.description}">Item description here...</li>
</ul>
1
Tunaki 22 Янв 2016 в 11:59