\n idを取得できない。\n\n\n
取得したい要素
\n\n\n```\n\n【src/resources/static/js/example.js】\n```javascript\n'use strict'\n{\n const target = document.getElementById('target');\n console.log(target); // 出力結果 -> null\n}\n```\n\n# 確認したこと①\nconsole.logで単純に文字列を取得することはできました。\nJavaScriptは正常に読み込めているようです。\n\n【src/resources/static/js/example.js】\n```javascript\n'use strict'\n{\n console.log('Hello'); // 出力結果 -> Hello\n\n const target = document.getElementById('target');\n console.log(target); // 出力結果 -> null\n}\n```\n\n# 確認したこと②\nHTMLファイルに直接JavaScriptを挿入した場合、正常に出力されました。\n\nsrc/resources/templates/example/example.html】\n```html\n\n\n\n \n \n idを取得できない。\n\n\n
取得したい要素
\n \n\n\n```\n\n# 確認したこと③\nidではなく、th:idと書き換えを試してみたのですが、症状が改善されませんでした。\n\n【src/resources/templates/example/example.html】\n```html\n\n\n\n \n \n idを取得できない。\n\n\n
取得したい要素
 \n\n\n```\n\n---\n足りない頭で考えつつも解決に至りませんでした、、、。\n解決方法、解決のヒントをお持ちの方はご協力いただけますと幸いです。\nよろしくお願いいたします。\n\n","answerCount":1,"upvoteCount":0,"datePublished":"2022-06-26T03:29:28.373Z","dateModified":"2022-06-26T15:34:38.000Z","acceptedAnswer":{"@type":"Answer","text":"HTMLの読み込みを待ってみてはいかがでしょう。\n\n【Document: DOMContentLoaded イベント - Web API | MDN】\n[https://developer.mozilla.org/ja/docs/Web/API/Document/DOMContentLoaded_event](https://developer.mozilla.org/ja/docs/Web/API/Document/DOMContentLoaded_event)","dateModified":"2022-06-26T15:28:45.000Z","datePublished":"2022-06-26T03:57:52.019Z","upvoteCount":2,"url":"https://teratail.com/questions/0wyh0qzuz5gk2g#reply-fnthiws3aroxzt"},"suggestedAnswer":[],"breadcrumb":{"@type":"BreadcrumbList","itemListElement":[{"@type":"ListItem","position":1,"name":"トップ","url":"https://teratail.com"},{"@type":"ListItem","position":2,"name":"JavaScriptに関する質問","url":"https://teratail.com/tags/JavaScript"},{"@type":"ListItem","position":3,"name":"JavaScript","url":"https://teratail.com/tags/JavaScript"}]}}}
質問するログイン新規登録
JavaScript

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

Q&A

解決済

1回答

823閲覧

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

KotaTakahashi

総合スコア8

JavaScript

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

0グッド

0クリップ

投稿2022/06/26 03:29

編集2022/06/26 06:33

0

0

解決したいこと

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

総合スコア69643

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

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

KotaTakahashi

2022/06/26 06:30

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.29%

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

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

質問する

関連した質問