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

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

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

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Bootstrap

BootstrapはウェブサイトデザインやUIのWebアプリケーションを素早く 作成する可能なCSSフレームワークです。 Twitter風のデザインを作成することができます。

Thymeleaf

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

HTML

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

Q&A

解決済

1回答

622閲覧

HTMLでfor文を使用したときにうまくセレクトボックスが表示できない

moshi

総合スコア90

Java

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Bootstrap

BootstrapはウェブサイトデザインやUIのWebアプリケーションを素早く 作成する可能なCSSフレームワークです。 Twitter風のデザインを作成することができます。

Thymeleaf

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

HTML

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

0グッド

0クリップ

投稿2020/02/18 05:46

前提・実現したいこと

Javaから渡されたリストをセレクトボックスに表示したいです。

発生している問題・エラーメッセージ

テキストのないセレクトボックスが作成されてしまいます。

試したこと

①まず最初にリストが渡されることを確認するため下記のように記述しました。

<div> <select id="sample" name="example" size="5" ondblclick="myFnc();" style="width: 100%"> <option th:value="${list[0]}" th:text="${list[0]}"></option> <option th:value="${list[1]}" th:text="${list[1]}"></option> <option th:value="${list[2]}" th:text="${list[2]}"></option> </select> </div>

すると、期待通りに以下のセレクトボックスが生成されました。
イメージ説明

②次に同じことを今度はfor文でリストの数だけ回して記述しようとしました。
(本当はlist[i]としたかったのですが、まずはきちんと表示されるのを確認するために下記のようにしています)

<div> <select id="sample" name="example" size="5" ondblclick="myFnc();" style="width: 100%"> <script type="text/javascript"> for (var i = 0; i < 10; i++) { document.write("<option th:value=\"${list[0]}\" th:text=\"${list[0]}\"></option>"); } </script> </select> </div>

しかし、結果は文字列が何もないセレクトボックスが生成されていました。
項目数は10個ありました。
イメージ説明

③最後にエスケープなどの記述の仕方がおかしかったのではないかと思い、もう一段階簡単なfor文を試しました。

<div> <select id="sample" name="example" size="5" ondblclick="myFnc();" style="width: 100%"> <script type="text/javascript"> for (var i = 0; i < 10; i++) { document.write("<option value=\"選択肢1\">sample1</option>"); } </script> </select> </div>

今度は期待通り文字列の表示されたセレクトボックスが生成されました。

③からエスケープの仕方は間違っていないと思うのですが、なぜ②がうまくいかないのでしょうか?

補足情報(FW/ツールのバージョンなど)

bootstrap4

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

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

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

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

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

guest

回答1

0

ベストアンサー

なぜ②がうまくいかないのでしょうか?

テンプレートエンジンに任せる仕事内容に着目すると違いがあります。

① はマークアップ文書内の要素が持つ属性を展開
② は javascript を展開
③ は展開する必要のない javascript

Thymeleaf は使ったことはないので、明確な回答はできませんが、「JavaScript の展開方法が求められる箇所で マークアップ文書の展開方法を期待して記述した」という印象を受けます。


ja - Thymeleaf のセクションに目を通すと以下の項目があります。

  • 6 「繰り返し処理」
  • 12.3 「高度なインライン評価とJavaScriptシリアライゼーション」

ヒントになりそうでしょうか。

後者の、javascript 変数に配列が渡されるようにすると、javascript が素直な処理として書けそうです。

投稿2020/02/18 11:56

AkitoshiManabe

総合スコア5434

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

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

moshi

2020/02/19 01:00

回答ありがとうございます。 ThymeleafとJavascriptがごっちゃになってたみたいです。 これでは動かないですねw ヒントとして頂いた繰り返し処理を元に解決ができました。 <select id="sample" name="sample" size="5" style="width: 100%" th:ondblclick="myFnc();"> <option th:each="list : ${list}" th:value="${list}" th:inline="text">[[${list}]]</option> </select> で期待する動作となりました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問