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

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

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

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Thymeleaf

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

Spring Boot

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

Q&A

解決済

1回答

6471閲覧

ThymeleafでのJavaScriptはjQueryの関数じゃないと動かない?

K-actus

総合スコア22

JavaScript

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Thymeleaf

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

Spring Boot

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

0グッド

0クリップ

投稿2021/04/16 08:05

こんにちは。
SpringBootについて初学者なので拙いところもあると思いますが、よろしくお願いします。

質問

表題の通りなのですが、先ほどThymeleaf上で<script type="text/javascript">タグの中にJavaScriptをべた書きしていました。
しかしgetElementByIdなどでの要素の取得が出来ませんした。
alertは動いたので結果を見てもnullが返ってくるだけで、JavaScript自体は動いてるのになぜか要素の取得が出来ていないという状況でした。

他のJavaScriptが動いているページとの違いは$(function () {}で関数化してるかどうかでした。
よってその部分をまるごと関数化したら動くようになりました。

これはThymeleafの仕様ですか?
それとも何か他に原因があると考えられますか?

調べても似たような現象が出てこなかったので質問させていただきました。
回答よろしくお願いします。

補足情報

Eclipse 2020 Java FullEdition
AmazonCorretto jdk15.0.2_7
SpringBoot 2.4.3
MySQL 8.0.23
Windows10 Pro 1909

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

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

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

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

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

guest

回答1

0

ベストアンサー

$はテンプレートエンジンとして特別な意味を持つのでth:inlineをscriptタグに指定しなければjQueryこそ動かないのでは。
どのようにコード書いてるか次第ですが、エスパー回答するとgetElementByIdを書いてたときは、要素が読み込まれる前にその処理通ってたのでは。
jQueryも結局はJavaScriptなので「jQueryの書き方でないと動かない」ということはあり得ません。
getElementByIdの結果がnullかどうかを確認してみて、nullであれば存在しない要素か、処理時に読み込まれてないかのどちらかです。

調べると分かりますが、$(function () {}はdocumet.ready つまり、htmlの読み込みを待機したうえで動作するのでonloadとほぼ同義です。

投稿2021/04/16 08:21

m.ts10806

総合スコア80861

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

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

K-actus

2021/04/19 02:17

jQuery云々の話ではなく、HTMLを読み込む順番が関係してるっていうことですね。 詳しく調べてみようと思います。 ありがとうございました。
m.ts10806

2021/04/19 02:23

いいえ。 「htmlが読み込まれてからJavaScriptが実行されているか否か」です。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問