首页 > 解决方案 > 如何访问 th:objects 列表并使用 th:each 遍历它?

问题描述

我正在尝试访问我的百里香对象列表并遍历它。

我尝试访问的项目类如下所示:

data class Orders(val orders: List<Order>)
data class Order(val orderNumber: Long,
                 val time: String,
                 val name: String,
                 val zipCode: Int,
                 val recipientType: String?,
                 val recipientName: String?,
                 val recipientZipCode: String?,
                 val recipientCity: String?,
                 val shoppingNote: String?,
                 val id: Int,
                 val orderRows: List<OrderRow>)

data class OrderRow(val id: Int,
                    val variantTitle: String,
                    val productTitle: String,
                    val amount: Int,
                    val units: List<Unit>)

data class Unit(val code: String,
                val redeemed: Boolean?)

我用来给我的模板提供订单列表的控制器如下:

@RequestMapping("/user")
    fun welcome(model: Model, principal: Principal): String {
        val user = userService.getUserInfo(principal.name)
        val listOfOrders = supplierService.getOrders(email, apiKey).orders

        model.addAttribute("user", user)
        model.addAttribute("listOfOrders", listOfOrders)

        return "user"
    }

我正在使用的模板看起来像这样

<div class="container">
    <table class="table" th:object="${listOfOrders}">
        <thead>
        <th>#</th>
        <th>Navn</th>
        <th>ID</th>
        </thead>
        <tbody>
        <th:block th:each="order: ${listOfOrders}">
            <tr class="accordion-toggle"
                data-toggle="collapse"
                th:data-target="'#accordion_'+${order.id}">
                <td th:text="${order.orderNumber}"></td>
                <td th:text="${order.name}"></td>
                <td th:text="${order.id}"></td>
            </tr>
            <tr>
                <td></td>
                <td colspan="6">
                    <div th:id="'accordion_'+${order.id}" class="collapse in">
                        <table class="table">
                            <thead>
                            <th>#</th>
                            <th>Navn</th>
                            <th>ID</th>
                            </thead>
                            <tbody>
                            <th:block th:each="row: ${order.orderRows}">
                                <tr class="accordion-toggle"
                                    data-toggle="collapse"
                                    th:data-target="'#accordion_'+${row.id}">
                                    <td th:text="${row.amount}"></td>
                                    <td th:text="${row.productTitle}"></td>
                                    <td th:text="${row.id}"></td>
                                </tr>
                                <tr>
                                    <td></td>
                                    <td colspan="6">
                                        <div th:id="'accordion_'+${row.id}" class="collapse in">
                                            Nothing to show yet.
                                        </div>
                                    </td>
                                </tr>
                            </th:block>
                            </tbody>
                        </table>
                    </div>
                </td>
            </tr>
        </th:block>
        </tbody>
    </table>
</div>

并且我使用 listOfOrders 作为 th:object 的第一个块完美地工作,但是对于我尝试访问 Order 的 orderRows 的第二次迭代失败并显示以下两条消息

org.thymeleaf.exceptions.TemplateProcessingException:评估 SpringEL 表达式的异常:“order.orderRows”(模板:“user” - 第 50 行,第 39 列)

org.springframework.expression.spel.SpelEvaluationException:EL1007E:在 null 上找不到属性或字段“orderRows”

我目前对此感到困惑,因为一旦我可以遍历 Orders orderRows,我还需要遍历 orderRows 单元。

而且我已经验证了添加到模型中的 listOfOrders 确实同时具有 orderRows 和 orderRows.units。

关于我缺少什么的任何建议或使它起作用的建议?

标签: spring-bootkotlinthymeleaf

解决方案


推荐阅读