使用th:each

对于我们的产品列表页面,我们需要一个控制器方法,来从服务层获得产品列表,并把它添加到模版上下文:

public void process(
        final HttpServletRequest request, final HttpServletResponse response,
        final ServletContext servletContext, final ITemplateEngine templateEngine)
        throws Exception {

    ProductService productService = new ProductService();
    List<Product> allProducts = productService.findAll(); 

    WebContext ctx = new WebContext(request, response, servletContext, request.getLocale());
    ctx.setVariable("prods", allProducts);

    templateEngine.process("product/list", ctx, response.getWriter());

}

然后,我们在我们的模版里使用th:each来遍历产品列表:

<!DOCTYPE html>

<html xmlns:th="http://www.thymeleaf.org">

  <head>
    <title>Good Thymes Virtual Grocery</title>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <link rel="stylesheet" type="text/css" media="all" 
          href="../../../css/gtvg.css" th:href="@{/css/gtvg.css}" />
  </head>

  <body>

    <h1>Product list</h1>

    <table>
      <tr>
        <th>NAME</th>
        <th>PRICE</th>
        <th>IN STOCK</th>
      </tr>
      <tr th:each="prod : ${prods}">
        <td th:text="${prod.name}">Onions</td>
        <td th:text="${prod.price}">2.41</td>
        <td th:text="${prod.inStock}? #{true} : #{false}">yes</td>
      </tr>
    </table>

    <p>
      <a href="../home.html" th:href="@{/}">Return to home</a>
    </p>

  </body>

</html>

你在上面看到的那个prod : ${prods}属性值的意思是“对于求值${prods}结果里的每一个元素,重复这段模版,在一个叫作prod的变量里使用当前的元素”。让我们给看到的每一个东西取一个名字:

  • 我们把${prods}称为被遍历表达式或者被遍历变量。

  • 我们把prod称为遍历变量。

需要注意prod遍历变量的作用范围是<tr>元素,这意味着可以使用内部标签,像<td>

Last updated