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

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

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

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

Thymeleaf

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

HTML

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

Spring Boot

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

Q&A

解決済

1回答

6971閲覧

button以外でsubmit送信したい

O_Y

総合スコア3

JavaScript

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

Thymeleaf

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

HTML

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

Spring Boot

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

0グッド

0クリップ

投稿2021/04/08 06:55

前提・実現したいこと

aタグ等のbutton以外でのsubmit処理を実現したいです。
・buttonタグやinputタグ(type="submit")を使うとクリック時のJavaScriptを待機せず遷移をしてしまうため、aタグ等で実現したい
・遷移先のパターンとして「submit」と「back」があり、「submit」のほうに遷移させたい
・サーバサイドはSpring BootでのJavaの環境
・HTMLのテンプレートとしてThymeleafを使用

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

遷移後のページで以下のようなメッセージが出ております。

Parameter conditions "back" OR "submit" not met for actual request parameters: _csrf= 以降省略

該当のソースコード

・HTML(前後省略)

<form id="aaaForm" method="post" th:action="@{/aaa}" th:object="${aaaForm}"> <a id="subTestA">テストリンク</a> </form>

・JavaScript

$("#subTestA").click(() => { // API等の処理は省略 var $form = $("#aaaForm"); $form.submit(); return false; });

・Java(Controllerクラス)

@PostMapping(value = "/aaa", params = "submit") public String postAaa(Model model) { // 内容は省略 } @PostMapping(value = "/aaa", params = "back") public String backAaa(Model model) { // 内容は省略 }

試したこと

・button type="submit" のクリックで遷移する(JavaSctriptの処理を無視して遷移してしまう)
・input type="submit" name="submit" のクリックで遷移する(現象は同上)

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2021/04/08 07:03

CSRFトークンを添えないとうまく行かないと思うので、HTMLのMETA要素で持たされているのであればそこから持ってくるなどしないといけないかと。
int32_t

2021/04/08 07:11

> buttonタグやinputタグ(type="submit")を使うとクリック時のJavaScriptを待機せず次の遷移をしてしまう その挙動は普通ではないので、何かミスをしていたのでしょう。
guest

回答1

0

ベストアンサー

javascript

1document.querySelector("#subTestA").addEventListener('click',e=>{ 2 e.preventDefault(); 3 e.target.closest('form').submit(); 4});

投稿2021/04/08 07:02

yambejp

総合スコア116736

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

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

O_Y

2021/04/08 07:56

e.preventDefault(); を組み込むことで解決することができました。 ご教示いただき、ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問