質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Thymeleaf

Thymeleaf(タイムリーフ)とは、Java用のテンプレートエンジンで、特定のフレームワークに依存せず使用することが可能です。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

Q&A

解決済

1回答

22847閲覧

Thymeleafでチェックボックスの値をcontroller側に渡したい

Sakura_miku

総合スコア2

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Thymeleaf

Thymeleaf(タイムリーフ)とは、Java用のテンプレートエンジンで、特定のフレームワークに依存せず使用することが可能です。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

0グッド

0クリップ

投稿2020/08/05 17:41

編集2020/08/06 02:15

現在、Thymeleafのチェックボックスを表示し、チェックされた値をcontroller側で受け取る処理がうまく実装出来ずに困っています。

ある条件に当てはまるセルのみを表示する一覧画面をThymeleafとSpringBootにて作成しています。
検索した結果をテーブル一覧に表示し、チェックボックスを付与します。

下記のように実装することで、検索結果(SelectList)を表示するテーブルにチェックボックスを付与するところまではできています。
ですが、出力されているチェックボックスにチェックを入れ、その値を取得するという実装ができていません。

例、3つチェックボックスが表示され、1,3番をチェックした場合は、1,3が入っている値を送信したいと思っています。

Thymeleaf

1 2<form method="post" th:action="@{/Test}" th:object="${FormEntity}"> 3 <!--検索処理した結果を表示するテーブル--> 4 <table> 5 <tr th:each="item : ${SelectList}"> 6 <td> 7 <input type="checkbox" name="checkbox" th:id="${item.Id}" th:value="${item.Id}" th:field="*{checks}" th:checked="${FormEntity.checks=='1'}" /> 8 <label th:for="${item.Id}" class="checkbox"></label> 9 </td> 10 <td> 11 <!--ほかにも表示している値はありますが、省略します。--> 12 </td> 13 </tr> 14 </table> 15 <!--送信ボタンを押下したらcontroller側にチェックを入れたボックスのvalue等を出力したいです。--> 16 <button value="submit" type="submit" name="submit">送信</button> 17</form>

上記の実装ですと、チェックボックスは表示できるのですが、チェックボックス自体が活性化していないような状態となっています。
th:fieldを削除するとチェックボックスは動作しますが、それだと値を取得することができなくなってしまいます。
どのようにすればチェックボックスを活性化させたまま、チェックを入れたボックスのvalue値等を取得できるのか教えていただけますと幸いです。

controller

1 @RequestMapping(value="/Test",params = "submit",method = RequestMethod.POST) 2 public ModelAndView Submit_Class(FormEntity FormEntity, Model model) throws ParseException { 3 //ここでどうにかしてチェックボックスにチェックを入れた値を取得したい。 4 } 5

ちなみにですが、実際に出力されているHTMLは以下の通りです。

HTML

1<input type="checkbox" name="checks" id="1" value="1"> 2<input type="hidden" name="_checks" value="on"> 3<label for="1" class="checkbox"></label> 4 5<input type="checkbox" name="checks" id="2" value="2"> 6<input type="hidden" name="_checks" value="on"> 7<label for="2" class="checkbox"></label> 8 9<input type="checkbox" name="checks" id="3" value="3"> 10<input type="hidden" name="_checks" value="on"> 11<label for="3" class="checkbox"></label>

皆様のお力をお借りできれば幸いです。

よろしくお願いいたします。

追記:
FormEntityの値を追加しました。
checkboxの配列を入れる予定のFormはこちらになります。

FormEntity

1 2@Getter 3@Setter 4public class FormEntity { 5 6 private String[] checks; 7 8 public void setChecks(String[] checks) { 9 this.checks = Checks; 10 } 11 12 public String[] getChecks() { 13 return checks; 14 } 15}

よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2020/08/05 23:33

FormEntityの定義をご提示ください
A-pZ

2020/08/05 23:34

FormEntityの内容も記載してください。
Sakura_miku

2020/08/06 02:16

失礼いたしました!FormEntityの値を追記させていただきました。 よろしくお願いします。
m.ts10806

2020/08/06 02:19

そもそも配列で受けとりたいのにhtmlが配列になってませんね。
Sakura_miku

2020/08/06 02:28

申し訳ありませんが、どのように変更すれば受け取ることができるようになるのでしょうか.... 配列は実装したことがなかったので... 実際に記載する方法を教えていただけますと幸いです。
guest

回答1

0

ベストアンサー

Formクラスで受け取るパラメータは配列でも良いのですが、java.util.List(ArrayList)で扱った方がより簡単に扱えるでしょう。

java

1@Getter @Setter 2public class FormEntity { 3 private List<String> checks = new ArrayList<>(); 4}

としたときに、Controllerでは、例えば

java

1 @PostMapping 2 public ModelAndView checked(ModelAndView mnv, @ModelAttribute("form") FormEntity form) { 3 4 List<String> checks = form.getChecks(); 5 mnv.addObject("checks", checks); 6 mnv.setViewName("checkbox"); 7 return mnv; 8 }

※Javaでは変数名は小文字から始めた方が良いです。

これを入出力するHTMLテンプレートは、繰り返し出力するチェックボックスの箇所だけ抜粋すると

html

1<table> 2 <tr th:each="item : ${SelectList}"> 3 <td> 4 <input type="checkbox" name="checks" th:id="${item.id}" th:value="${item.id}" 5 th:checked="${form.checks.contains(item.id)}" /> 6 <label th:for="${item.id}" class="checkbox"></label> 7 </td> 8 <td> 9 <!--ほかにも表示している値はありますが、省略します。--> 10 </td> 11 </tr> 12 </table>

と、checksはList型なので、contains(itemが持っているid)で比較できます。
hiddenで渡さなくても実現可能です。

参考実装:
https://github.com/A-pZ/spring-thymeleaf-sample/blob/develop/src/main/java/com/github/apz/controller/checkbox/CheckboxController.java
https://github.com/A-pZ/spring-thymeleaf-sample/blob/develop/src/main/resources/templates/checkbox.html

投稿2020/08/06 11:49

A-pZ

総合スコア12011

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Sakura_miku

2020/08/12 11:36

A-pZ様の方法で試したところ、無事チェックボックスの値を取得することができるようになりました!ありがとうございました!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問