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

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

新規登録して質問してみよう
ただいま回答率
85.46%
Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

Router

Routerは、異なるネットワーク同士を相互に接続するための通信機器。インターネットでのデータを自動的に振り分け、一つのインターネット回線を複数のコンピュータで使用することが可能です。DHCPによりIPアドレスを自動的に割振りすることもできます。

Vuex

Vuexは、Vue.js アプリケーションのための状態管理ライブラリです。アプリケーション内で使用するコンポーネントのための集中データストアを提供。コンポーネント同士でデータをやり取りし、処理のフローを一貫させたり、データの見通しを良くすることができます。

Q&A

解決済

1回答

4357閲覧

Vue3 ページ離脱時のアラートの実行結果を取得することはできますか?

yooonb

総合スコア17

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

Router

Routerは、異なるネットワーク同士を相互に接続するための通信機器。インターネットでのデータを自動的に振り分け、一つのインターネット回線を複数のコンピュータで使用することが可能です。DHCPによりIPアドレスを自動的に割振りすることもできます。

Vuex

Vuexは、Vue.js アプリケーションのための状態管理ライブラリです。アプリケーション内で使用するコンポーネントのための集中データストアを提供。コンポーネント同士でデータをやり取りし、処理のフローを一貫させたり、データの見通しを良くすることができます。

0グッド

0クリップ

投稿2021/09/13 10:17

訪問いただきありがとうございます。
ページ離脱時・リロード時に出るアラート周りの実装をしています。
アラートは出るようになったのですが、どうしてもアラート後の処理を制御することができません。
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})

環境

よろしくお願いいたします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

離れることを許可したあとの制御は完全にブラウザ側のものとなっていますので、原理的に不可能ですし、(特にこの場合は)無意味です。

ブラウザJavaScriptで記録されているstateは、ブラウザによるページ遷移で消し飛びますので、わざわざリセットする必要性もありません。

投稿2021/09/13 10:25

maisumakun

総合スコア145208

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

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

yooonb

2021/09/13 10:33

回答ありがとうございます。 > 離れることを許可したあとの制御は完全にブラウザ側のものとなっていますので、原理的に不可能 そうなんですね。勉強不足でした。 > ブラウザJavaScriptで記録されているstateは、ブラウザによるページ遷移で消し飛びますので、わざわざリセットする必要性もありません。 今回の場合、stateはブラウザを閉じても保持する設定にしているので、 明示的にクリアしないと消えないようになっています。 保持するstateと、クリアしたいstateがあります。 そのため、実行結果を検知したかったのですが、 ロジックを見直さないといけないかもしれませんね。。 再度、見直してみます。
yooonb

2021/09/13 10:41 編集

1.onUnmounted時にクリアできるか 2. 逆にマウント時にクリアできるか 試してみます。
yooonb

2021/09/13 10:54

上記の1番の方法で、やりたいことを実現できました! 複雑に考えていたようでした。 的確な回答を頂き、ありがとうございました。 ベストアンサーにさせていただきます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問