![](https://cdn-ak-scissors.b.st-hatena.com/image/square/79d3ae2a02f60eb19ed088e671ef876bcad5084e/height=288;version=1;width=512/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Farticle-ogp-background-9f5428127621718a910c8b63951390ad.png%3Fixlib%3Drb-4.0.0%26w%3D1200%26mark64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZoPTMzNiZ0eHQ9JUUzJTgzJTk2JUUzJTgzJUE5JUUzJTgyJUE2JUUzJTgyJUI2JUUzJTgzJTkwJUUzJTgzJTgzJUUzJTgyJUFGJUUzJTgxJUE3JUUzJTgwJThDJUUzJTgxJUExJUUzJTgyJTg3JUUzJTgxJUEzJUUzJTgxJUE4JUU1JUJFJTg1JUUzJTgxJUEzJUUzJTgxJUE2JUUzJTgwJThEJUU3JTlBJTg0JUUzJTgxJUFBJUUzJTgyJUEyJUUzJTgzJUE5JUUzJTgzJUJDJUUzJTgzJTg4JUUzJTgyJTkyJUUzJTgxJUEwJUUzJTgxJTk5aG9va3MmdHh0LWNvbG9yPSUyMzIxMjEyMSZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT01NiZ0eHQtY2xpcD1lbGxpcHNpcyZ0eHQtYWxpZ249bGVmdCUyQ3RvcCZzPTEwOGViZDQwMmY3MWFhMjU5ZGE3OTYxMjJiNWJmOGRl%26mark-x%3D142%26mark-y%3D112%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTcxNiZ0eHQ9JTQwbml0YWtpbmcmdHh0LWNvbG9yPSUyMzIxMjEyMSZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT0zMiZ0eHQtYWxpZ249bGVmdCUyQ3RvcCZzPWVhMDRjYjZjMTg1OGY1MzQ5NDk4YzA1ZWIyZjU2OTBl%26blend-x%3D142%26blend-y%3D491%26blend-mode%3Dnormal%26s%3Dc2a8a19f0dd833c29314b7751823521b)
エントリーの編集
![loading...](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/common/loading@2x.gif)
エントリーの編集は全ユーザーに共通の機能です。
必ずガイドラインを一読の上ご利用ください。
ブラウザバックで「ちょっと待って」的なアラートをだすhooks - Qiita
記事へのコメント0件
- 注目コメント
- 新着コメント
このエントリーにコメントしてみましょう。
注目コメント算出アルゴリズムの一部にLINEヤフー株式会社の「建設的コメント順位付けモデルAPI」を使用しています
![アプリのスクリーンショット](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/entry/app-screenshot.png)
- バナー広告なし
- ミュート機能あり
- ダークモード搭載
関連記事
ブラウザバックで「ちょっと待って」的なアラートをだすhooks - Qiita
import { useEffect } from 'react'; /** * 一度入力した後にリロードすると、確認ダイアログを出す。 *... import { useEffect } from 'react'; /** * 一度入力した後にリロードすると、確認ダイアログを出す。 */ export const useOnReloadAlert = (enable: boolean = true) => { useEffect(() => { if (!enable) return; window.history.pushState(null, '', window.location.pathname); const onReload = (event: BeforeUnloadEvent) => { event.preventDefault(); event.returnValue = ''; }; window.addEventListener('beforeunload', onReload); return () => {