🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Java

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

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

Thymeleaf

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

Q&A

解決済

1回答

15938閲覧

thymeleaf js値埋め込み方について

1111777

総合スコア9

Java

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

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

Thymeleaf

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

0グッド

0クリップ

投稿2019/10/14 00:48

Java

1public class User { 2 public String name; 3 public Integer age; 4 5 public String getName() { 6 return name; 7 } 8 9 public Integer getAge() { 10 return age; 11 } 12}

thymeleaf

1<script th:inline="javascript"> 2/*<![CDATA[*/ 3 ... 4 5 var user = {"age":33,"name":"Mitsuyuki Shiiba"}; 6 7 ... 8/*]]>*/ 9</script>

thymeleafでjsに値を渡すとき/<![CDATA[*/  /*]]>/  の中にvar user = {"age":33,"name":"Mitsuyuki Shiiba"};このように値を詰めるやり方とは別に、

コントローラー側でlistにaddしたデータを渡すことは可能でしょうな、以下のような書き方は可能でしょうか?

HTML

1List<Integer> user = new ArrayList<>(); 2List<Integer> users = new ArrayList<>(); 3 4<script th:inline="javascript"> 5/*<![CDATA[*/ 6 ... 7 8 var user = user(); 9 var users = users; 10 11 ... 12/*]]>*/ 13</script> 14 15

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

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

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

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

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

guest

回答1

0

ベストアンサー

SpringMVCのControllerからThymeleaf内のJavaScriptへ値をJSON形式で渡す方法は、以下のように JacksonのObjectMapperなどを利用すれば可能です。

java

1package com.github.apz.springsample.controller; 2 3import java.util.ArrayList; 4import java.util.List; 5 6import org.springframework.stereotype.Controller; 7import org.springframework.web.bind.annotation.GetMapping; 8import org.springframework.web.servlet.ModelAndView; 9 10import com.fasterxml.jackson.core.JsonProcessingException; 11import com.fasterxml.jackson.databind.ObjectMapper; 12 13@Controller 14public class JSONSampleController { 15 16 public JSONSampleController(ObjectMapper objectMapper) { 17 this.objectMapper = objectMapper; 18 } 19 20 final ObjectMapper objectMapper; 21 22 @GetMapping("jsonSample") 23 public ModelAndView display(ModelAndView mnv) throws JsonProcessingException { 24 25 mnv.addObject("itemList", objectMapper.writeValueAsString(itemList())); 26 mnv.setViewName("itemList"); 27 return mnv; 28 } 29 30 List<SampleItem> itemList() { 31 List<SampleItem> items = new ArrayList<SampleItem>() {{ 32 add( new SampleItem(1, "Aphpa")); 33 add( new SampleItem(2, "Beta")); 34 add( new SampleItem(3, "Charly")); 35 add( new SampleItem(4, "Delta")); 36 }}; 37 38 return items; 39 } 40 41 class SampleItem { 42 public SampleItem(int id,String name) { 43 this.id = id; 44 this.name = name; 45 } 46 public int getId() { 47 return id; 48 } 49 public String getName() { 50 return name; 51 } 52 private int id; 53 private String name; 54 } 55} 56

html

1<!DOCTYPE html> 2<html xmlns:th="http://www.thymeleaf.org"> 3<head> 4<meta charset="UTF-8"> 5</head> 6<body> 7<script th:inline="javascript"> 8/*<![CDATA[*/ 9 var itemList = /*[[ ${itemList} ]]*/; 10 console.debug( itemList ); 11/*]]>*/ 12</script> 13</body> 14</html>

https://qiita.com/alpha_pz/items/d21f818b5792d3880731

投稿2019/10/14 03:59

A-pZ

総合スコア12011

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

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

1111777

2019/10/14 06:59

凄いです!!!有難うございます!!!なんでも知ってるのですね!! めちゃかっこいいです( ;∀;) こんなプログラマーになりたい☺️
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問