小編這次要給大家分享的是詳解SpringBoot中如何實現Controller接收對象列表,文章內容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
如果Spring Boot中對應的Controller要接收一個對象,該對象中又存放了一個List列表,那么頁面該如何傳遞相關應的參數信息呢。
本篇文章給大家一個簡單的示例,提供一種實現方式。
實體類
首先看實體類的結構(注意使用了Lombok):
@Data public class Rules { private List<Rule> rules; }
對應Rule實體類代碼如下:
@Data public class Rule { /** * 類名 */ private String className; /** * 字段名稱 */ private String column; /** * 操作符 */ private String operate; /** * 對應值 */ private String value; }
對應Controller方法
@Controller public class ManagerRulesController { @PostMapping("/rules/add") public String addDrl(Rules rules) { if (rules != null) { List<Rule> ruleList = rules.getRules(); for (Rule rule : ruleList) { // 具體業務處理 } return "result"; } }
對應頁面呈現
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>規則頁面管理頁面</title> <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.4.1/dist/css/bootstrap.min.css" rel="external nofollow" /> </head> <body class="container"> <h5>頁面拼接模式</h5> <form method="post" action="/rules/add"> <#--第一條條件--> <div id="condition-0"> <div class="form-group"> <label>金額:</label> <input type="hidden" name="rules[0].column" value="amount"> 操作屬性操作: <select class="form-control" name="rules[0].operate"> <option value=">">大于</option> <option value="<">小于</option> </select> 屬性值: <input type="text" class="form-control" name="rules[0].value" placeholder="輸入值" value="1"> </div> </div> <div id="condition-1"> <div class="form-group"> <label>金額:</label> <input type="hidden" name="rules[1].column" value="amount"> 操作屬性操作: <select class="form-control" name="rules[1].operate"> <option value="<">小于</option> <option value=">">大于</option> </select> 屬性值: <input type="text" class="form-control" name="rules[1].value" placeholder="輸入值" value="100"> </div> </div> <button type="submit" class="btn btn btn-info">提交</button> </form> </body> </html>
注意要提交的頁面元素的name值為“rules[1].column”。通過這種形式來指定列表中的第幾個元素的具體屬性值是什么。
看完這篇關于詳解SpringBoot中如何實現Controller接收對象列表的文章,如果覺得文章內容寫得不錯的話,可以把它分享出去給更多人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。