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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Spring Security

Spring Securityは、Springのサブプロジェクトの一つでWebアプリケーションに必要な機能を追加します。正規ユーザーであるかを確認するための「認証機能」と、ユーザーのアクセスを制御する「認可機能」を簡単に追加することが可能です。

Java

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

JavaScript

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

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

HTML

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

Q&A

解決済

2回答

2205閲覧

JavaScriptで設定した値を画面遷移後も維持させる方法について

taitasan

総合スコア14

Spring Security

Spring Securityは、Springのサブプロジェクトの一つでWebアプリケーションに必要な機能を追加します。正規ユーザーであるかを確認するための「認証機能」と、ユーザーのアクセスを制御する「認可機能」を簡単に追加することが可能です。

Java

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

JavaScript

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

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

HTML

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

0グッド

1クリップ

投稿2022/06/28 07:23

前提
Java(Spring boot)、HTML(Thymeleaf)、Javascript(Ajax、jquery)を使用し、簡単なWebサービスを構築しています。

発生している問題
Ajaxを用いて、お気に入りボタンを押すとDBへそのお気に入りを追加できる機能を作りました。
その際にJQueryを用いて、お気に入りボタンを押すとそのボタンの表示が「お気に入り」→「お気に入り解除」に切り替わる処理を作成しました。
イメージ説明
しかし、他の画面に遷移してから再度このお気に入りボタンを押せる画面に戻ってくると「お気に入り解除」と切り替えたはずのボタンも全て「お気に入り」の表示に戻ってしまいます。

実現したいこと
他の画面に遷移して、再びお気に入りボタンを押せる画面に戻っても一度切り替えた設定を維持させる方法

該当のソースコード

html

1<!--他の画面からお気に入りが押せる画面へ遷移するリンク--> 2 <a th:href="@{/main-page}"><img class="header-logo" src="logo.png" width="80px"></a> 3456<form th:action="@{/execute-favorite}" method="post" > 7 <input type="submit" class="button" value="お気に入り" th:name="${article.id}" > 8 </form>

JavaScript

1$(function () { 2 $(document).on('submit', '.favorite-button', function () { 3 4 $.ajax({ 5 url: "http://localhost:8080/execute-favorite" 6 , type: 'POST' 7 , dataType: 'json' 8 , data: { 9 _csrf: $("*[name=_csrf]").val() 10 } 11 , async: true 12 }).done(function () { 13 console.log("通信成功!!") 14 }).fail(function () { 15 console.log("通信失敗、、、") 16 }).always(function () { 17 console.log("通信終了") 18 }) 19 }) 20 21//ボタン表示切り替えの処理 22 $('.button',this).on('click', function(){ 23 if($(this).val() === 'お気に入り'){ 24 $(this).val('お気に入り解除') 25 } else if($(this).val() === 'お気に入り解除'){ 26 $(this).val('お気に入り') 27 } 28 })

Java

1@RequestMapping("/execute-favorite") 2@ResponseBody 3 public void executeFavorite(@AuthenticationPrincipal LoginUser user, Integer id) { 4 if (favoriteService.load(user.getRegister().getId(), id).isEmpty()) { 5 favoriteService.insert(user.getRegister().getId(), id); 6 } else { 7 Favorite favorite = favoriteService.delete(user.getRegister().getId(), id); 8 favoriteService.delete(favorite.getId()); 9 } 10 }

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

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

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

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

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

guest

回答2

0

ベストアンサー

ブラウザの戻るボタンのはなしであれば、sPy2bUDOZ4uRa7t さんの回答で解決できるでしょう。

ボタンやリンクであちこち画面遷移をしたときのはなしであれば、サーバ側で「状態」を管理する必要があるでしょう。「セッション情報 引き渡し」などをキーワードにgoogleに訊くとよいかと。
管理したい「状態」や保持したい期間によっては、データベースの利用も視野に入るでしょう。

投稿2022/06/28 08:43

編集2022/06/28 08:45
shiketa

総合スコア3971

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

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

taitasan

2022/06/29 02:42

回答ありがとうございます! ボタンやリンクで画面遷移をした時に、状態を管理したいので再度調べてみます!
guest

0

HTML5のHistory APIを用いてブラウザの戻る処理をハックする | selfree
で説明されている処理を利用して、戻るボタンで戻ったときにページの初期化を実行するようにでもしたらいいのかもしれない。

投稿2022/06/28 07:46

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問