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

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

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

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

jQuery

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

Q&A

解決済

1回答

9466閲覧

beforeunloadのキャンセル時に、メッセージを表示したい

tetakaha759

総合スコア22

JavaScript

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

jQuery

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

0グッド

1クリップ

投稿2021/12/28 06:15

前提・実現したいこと

Javascript(jQUeryでも可)にて、beforeunloadイベントをキャンセルした際(つまり、そのページに留まった際)に、alertなどでメッセージを表示したいと考えております。

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

googleにて「beforeunload キャンセル時 メッセージ」などのキーワードで検索しても、そのようなやり方を見出すことができませんでした。

そもそも、「キャンセル時に独自のメッセージを表示」させること自体が可能なのでしょうか??

該当のソースコード

Javascript

1window.addEventListener("beforeunload", (ev) => { 2 ev.preventDefault (); 3 ev.returnValue = "check"; 4 5 //キャンセル時に実行されるコード? 6 //「ページに留まりました」というメッセージを表示させたい 7 //可能であれば、メッセージ表示以外の処理も実行したい 8 9}); 10

試したこと

上記の「キャンセル時に実行されるコード?」が分からず、悩んでおります。
コールバック関数でも設定するのでしょうか?

ご存じな方がいらっしゃったら、ぜひご教示いただきたく存じます。

補足情報(FW/ツールのバージョンなど)

beforeunloadイベントで、「ページ離脱の独自メッセージ」が設定できないとされている、Chromeにて試しています
(バージョン: 96.0.4664.110)

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

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

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

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

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

guest

回答1

0

ベストアンサー

confirmでいいでしょうか?

Javascript

1window.addEventListener("beforeunload", (ev) => { 2 ev.preventDefault (); 3 ev.returnValue = "check"; 4 if( confirm('ページを閉じますか?') ){ 5 alert('ページから離れます'); 6 return true; 7 } 8 else { 9 alert('ページに留まりました'); 10 return false; 11 } 12});

投稿2021/12/28 10:55

skys215

総合スコア910

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

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

tetakaha759

2021/12/28 23:40

ご回答、ありがとうございました。 上記のコードをコピーして試してみましたが、Chromeではページを離れる際も、キャンセルした際もメッセージは表示されませんでした。 Chromeのデベロッパーツールで確認してみると、「Blocked confirm('ページを閉じますか?') during beforeunload.」というエラーメッセージが表示されることから、やはり confirm は Chromeではブロックされているようです。
skys215

2021/12/29 01:34

window.addEventListener("beforeunload", (ev) => { ev.preventDefault (); ev.returnValue = 'ページを閉じますか?'; }); だとどうですか?
tetakaha759

2021/12/29 03:50

Chromeでも、Edgeでも、ソースに記載された「ページを閉じますか?」ではなく、「サイトを離れますか?」といったブラウザ側のメッセージが表示されてしまいます。 この状態でキャンセルした場合も、メッセージは表示されません。
tetakaha759

2021/12/30 05:06

あの後にいろいろと試して、どうやらキャンセル時にメッセージを表示させるのは無理っぽいことが分かりました。 やり方を変えて、「beforeunload」のイベント発生時に処理を実行させるようにしました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問