訪問いただきありがとうございます。
ページ離脱時・リロード時に出るアラート周りの実装をしています。
アラートは出るようになったのですが、どうしてもアラート後の処理を制御することができません。
vue, jsに詳しい方、アドバイスいただけると嬉しいです。
前提・実現したいこと
(vue3で)
ページ離脱時(リロード時)のアラートが、許可されたかどうかを検知して、関数を実行したい
※流れ↓
- リロード
- 標準のアラートが表示される(「サイトを離れますか?」)
- 「このページを離れる」押下後、stateをクリアする関数を実行
- 「キャンセル」した場合は、クリア関数を実行しない
困っていること
アラート内の「このページを離れる」「キャンセル」ボタン
どちらを押下したか検知したいです。
その結果によって、
上記(実現したいこと)の通りに処理を切り替えたいです。
やったこと
下記コード①②で、stateをクリアする関数を実行しましたが、
期待どおりの挙動をしません。
// コメントに書いています
コード
js
1import { defineComponent, ref, onUnmounted, watch, reactive, computed, onBeforeMount, onBeforeUnmount } from 'vue' 2import { useStore } from "vuex" 3import { onBeforeRouteLeave } from 'vue-router' 4 5export default defineComponent({ 6 name: 'SampleLayout', 7 8 setup() { 9 const store = useStore() 10 11 12 // stateの一部をクリアする 13 const clear = () => { 14 store.commit('sample/clear') 15 } 16 17 const onBeforeunloadHandler = (evt) => { 18 evt.returnValue = '編集中の内容は失われます。よろしいですか?' 19 20 // ここでやると、リロードをキャンセルしても、実行されてしまう ー① 21 // clear() 22 } 23 24 // created 25 window.addEventListener('beforeunload', onBeforeunloadHandler, false) 26 27 onBeforeUnmount(() => { 28 LOG.dev("before destoroy") 29 window.removeEventListener('beforeunload', onBeforeunloadHandler, false) 30 31 // 実行されない 32 // clear() ー② 33 }) 34 } 35})
環境
- vue3
- http://localhost:8080/(ホットリロード有効)
- windows
- vsCode
よろしくお願いいたします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/09/13 10:33
2021/09/13 10:41 編集
2021/09/13 10:54