9cubed
ブログ | Tailwind | Vite | Python | Node.js | Linux | PowerShell | その他 | 将棋ウォーズ | 歌の練習
< 前の記事

jQuery - ページが閉じられる時のイベント(unload)

次の記事 >

jQuery - チェックボックス(checkbox)のチェックの設定と取得

jQuery

jQuery - ページが閉じられる直前のイベント(beforeunload)

公開日:2018-12-21
更新日:2019-05-14

1. 概要

ページを閉じたり、画面遷移する直前に、beforeunloadイベントが発生します。
このイベント内で文字列を return すると、
画面遷移の確認メッセージが表示され、ページの離脱抑止が行えます。
return した文字列の扱い方は、ブラウザによって異なります。
また、ページ表示後に、一度画面のどこかをクリックしないと、確認メッセージが表示されずに画面遷移する場合があります。

$(window).on('beforeunload', function() {
	処理;
});

//画面遷移時に確認メッセージが表示されます
$(window).on('beforeunload', function() {
	処理;
	return "確認";
});

2. サンプル

チェックボックスにチェックを付けて、画面遷移をしようとすると、確認メッセージが表示されます。
但し、送信ボタンがクリックされた場合には、確認メッセージを表示せずに、画面遷移できるようにしています。

<!DOCTYPE html><html><head><meta charset="UTF-8"><title>jQuery</title><style>body{color:#fff; background-color:#000;}</style></head>
<body>
  <script src="https://code.jquery.com/jquery-3.3.1.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script>

  <form action="0026-2.html">
    <input type="checkbox" checked="checked" />ページの離脱抑止を行う<br />
    <br />
    <input type="submit" value="送信" />
  </form>

  <script>
    $(function(){

      $(window).on("beforeunload", function() {
        if ( $(":checkbox").prop('checked') ) {
          //チェックが付いている場合は、画面遷移の確認メッセージを表示します
          return "確認";
        }
      });

      $(":submit").on("click", function() {
        //beforeunload イベントを削除して、確認メッセージが表示されないようにします
        $(window).off("beforeunload");
      });

    });
  </script>
</body></html>

実行結果:画面



< 前の記事

jQuery - ページが閉じられる時のイベント(unload)

次の記事 >

jQuery - チェックボックス(checkbox)のチェックの設定と取得

YouTube X

新着一覧

  • SCSS のインストールVite
  • Tailwind CSS のプロジェクトの作成Tailwind
  • TypeScriptのプロジェクトの作成Vite
  • Flask のインストールと動作確認Python
  • 簡易Webサーバーの作成Python
  • pipeline で文章の生成Python
  • pipeline で文章の要約Python
  • 音声から文字起こしPython
  • Node.js のインストールNode.js
  • .ps1(PowerShellスクリプト)を実行可能にするPowerShell

アーカイブ

  • 2025/12
  • 2025/11
  • 2025/10
  • 2025/09
  • 2025/08

以前のカテゴリー一覧

  • CakePHP3
  • CentOS7
  • HTML・CSS・JavaScript
  • Haskell
  • JavaScript
  • Kotlin
  • Laravel5
  • PHP
  • Python
  • Ruby
  • RubyOnRails5
  • TypeScript
  • Vue.js
  • Webサーバ講座
  • Webプログラミング講座
  • jQuery
  • linux
  • パソコン講座
  • ブログ
  • プログラミング講座
  • メモ帳作成講座
  • 数学

Copyright © 9cubed. All Rights Reserved.

プライバシーポリシー 利用規約
▲