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

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

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

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

Q&A

解決済

1回答

383閲覧

HTML内のidの値を別のJSファイルで取得できない。

KotaTakahashi

総合スコア8

JavaScript

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

0グッド

0クリップ

投稿2022/06/26 03:29

編集2022/06/26 06:33

解決したいこと

Thymeleafを使用したHTMLファイル内のid属性をつけた要素の値を取得ができません。
以下詳細のように、idを取得しようとしてもnullが返ってきてします。

環境

  • Spring Boot 2.6.7
  • Java11
  • Thymeleaf

ディレクトリ構成

ProjectRoot ┗src ┗main ┣java ┗resources ┣static ┃ ┗js ┃ ┗example.js ┗templates ┗demo ┗example.html

値を取得できないコード

以下のコードで値の取得を試みたのですが、nullが返ってきてしまいます。
【src/resources/templates/example/example.html】

html

1<!DOCTYPE html> 2<html xmlns:th="http://www.thymeleaf.org"> 3<head> 4 <meta charset="UTF-8"> 5 <script th:src="@{/js/example.js}"></script> 6 <title>idを取得できない。</title> 7</head> 8<body> 9 <div id="target">取得したい要素</div> 10</body> 11</html>

【src/resources/static/js/example.js】

javascript

1'use strict' 2{ 3 const target = document.getElementById('target'); 4 console.log(target); // 出力結果 -> null 5}

確認したこと①

console.logで単純に文字列を取得することはできました。
JavaScriptは正常に読み込めているようです。

【src/resources/static/js/example.js】

javascript

1'use strict' 2{ 3 console.log('Hello'); // 出力結果 -> Hello 4 5 const target = document.getElementById('target'); 6 console.log(target); // 出力結果 -> null 7}

確認したこと②

HTMLファイルに直接JavaScriptを挿入した場合、正常に出力されました。

src/resources/templates/example/example.html】

html

1<!DOCTYPE html> 2<html xmlns:th="http://www.thymeleaf.org"> 3<head> 4 <meta charset="UTF-8"> 5 <!-- <script th:src="@{/js/example.js}"></script> --> 6 <title>idを取得できない。</title> 7</head> 8<body> 9 <div id="target">取得したい要素</div> 10 <script> 11 'use strict' 12 { 13 const target = document.getElementById('target'); 14 console.log(target); // 出力結果 -> <div id="target">取得したい要素</div> 15 } 16 </script> 17</body> 18</html>

確認したこと③

idではなく、th:idと書き換えを試してみたのですが、症状が改善されませんでした。

【src/resources/templates/example/example.html】

html

1<!DOCTYPE html> 2<html xmlns:th="http://www.thymeleaf.org"> 3<head> 4 <meta charset="UTF-8"> 5 <script th:src="@{/js/example.js}"></script> 6 <title>idを取得できない。</title> 7</head> 8<body> 9 <div th:id="target">取得したい要素</div> <!--出力結果:null--> 10</body> 11</html>

足りない頭で考えつつも解決に至りませんでした、、、。
解決方法、解決のヒントをお持ちの方はご協力いただけますと幸いです。
よろしくお願いいたします。

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

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

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

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

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

m.ts10806

2022/06/26 06:15

既存回答の通り、Thymeleafが影響するものではないですね。
KotaTakahashi

2022/06/26 06:34

ありがとうございます。 てっきりThymeleafの使用方法に原因があるのかとばかり思っていました。 勉強になりました。
guest

回答1

0

ベストアンサー

HTMLの読み込みを待ってみてはいかがでしょう。

【Document: DOMContentLoaded イベント - Web API | MDN】
https://developer.mozilla.org/ja/docs/Web/API/Document/DOMContentLoaded_event

投稿2022/06/26 03:57

kei344

総合スコア69444

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

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

KotaTakahashi

2022/06/26 06:30

ありがとうございます!教えていただいた通り修正してみたら無事に読み込みました。 勉強になりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問