Spring Boot和Thymeleaf,将变量传递给控制器

时间:2020-10-21 13:02:39

标签: java spring-boot spring-mvc thymeleaf

我有一个控制器来处理产品的购买,它有两个参数,计数-产品的数量和id-用户购买的产品的ID。

@PostMapping("/buyproduct")
public String buyProduct(@RequestParam int count,@RequestParam long id){
    Product product = productRepository.findById(id);
    int activeCount = product.getCount();
    if (activeCount-count<0){
        return "redirect:/";
    }
    product.setCount(activeCount-=count);
    productRepository.save(product);
    return "redirect:/buyproductsuccessful";
}

在index.html中,我已使用Thymeleaf列出了数据库中所有可用的产品。

<div class="col-12 col-md-6 col-lg-4" th:each="element : ${products}">
        <div class="card">
            <img class="card-img-top" src="https://picsum.photos/362/180" alt="Card image cap">
            <div class="card-body">
                <h5 style="text-align: center" class="card-title" th:text="${element.getName()}"</h5>
                <span th:text="${element.getCost()}"></span></p>
                <span th:text="${element.getCount()}"></span> </p>
                ...

每个产品都有自己的按钮,单击时会弹出一个弹出窗口,您需要在其中输入购买的产品的数量和银行数据(我不处理它们,我还不需要它们),然后在其中还是一个隐藏的字段,我想在其中放置产品ID,以便以后可以将其传递给控制器​​。

<form action="#" th:action="@{/buyproduct}" th:object="${element}" method="post">
                                <!-- Modal Header -->
                                <div class="modal-header">
                                    <h4 class="modal-title" style="color: #368819"></h4>
                                    <button type="button" class="close" data-dismiss="modal">&times;</button>
                                </div>

                                <!-- Modal body -->
                                <div class="modal-body">
                                    <div>
                                        <input type="hidden" name="id" th:value="*{getId()}">
                                        <label><b>რაოდენობა</b></label><br>
                                        <input class="col-4" type="number" min="1" value="1" name="count" required><br><br>
                                        <label><b></b></label><br>
                                        <input class="col-12" type="text"><br><br>
                                        <label><b></b></label><br>
                                        <input class="col-12" type="date"><br><br>
                                        <label><b>CVV/CVC</b></label><br>
                                        <input class="col-4" type="text"><br><br>
                                    </div>
                                </div>

                                <!-- Modal footer -->
                                <div class="modal-footer">
                                    <button type="submit" class="btn btn-success"></button>
                                    <button type="button" class="btn btn-danger" data-dismiss="modal"></button>
                                </div>
                                </form>

但是Thymeleaf每次都会传递第一个产品的ID,这是我的错误?

1 个答案:

答案 0 :(得分:0)

问题出在Bootstrap模态示波器上。

<button style="margin-left: 40%" type="button" class="btn btn-success" data-toggle="modal" data-target="#myModal">
<div class="modal" id="myModal">

修复后,它看起来像这样。

<button style="margin-left: 40%" type="button" class="btn btn-success" data-toggle="modal" th:attr="data-target='#id-' + ${element.getId()}">
<div class="modal" th:id="'id-' + ${element.getId()}">