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

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

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

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

Q&A

解決済

1回答

7201閲覧

ページ離脱時のイベントをiOSのブラウザでも発生させたい

poteto4401

総合スコア57

Vue.js

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

0グッド

0クリップ

投稿2019/04/12 03:27

編集2019/04/28 03:58

質問

Vue.jsでページ離脱時にAPIを実行したいのですが、表題の通りiOSからでは期待した動作が行われません。
別の方法をご教授いただけないでしょうか。

ソースコード

vue

1mounted: function() { 2 // ページから離れる前にここが呼ばれる 3 window.addEventListener('beforeunload', function() { 4 this.request(); 5 }); 6}, 7methods: { 8 request: function() { 9 axios 10 .post("/api/update", this.params) 11 .then(function(response) {}) 12 .catch(function(err) {}); 13 }, 14}

試したこと

iOS(Safari)ではbeforeunloadは呼ばれないようなので、pagehideに置き換えましたが、
axiosが実行されません。

vue

1mounted: function() { 2 // ページから離れる前にここが呼ばれる 3 window.addEventListener('pagehide', function() { 4 this.request(); 5 }); 6}, 7methods: { 8 request: function() { 9 console.log('ここまでは動く') 10 axios 11 .post("/api/update", this.params) 12 .then(function(response) {}) 13 .catch(function(err) {}); 14 }, 15}

参考

https://qiita.com/ta__ho/items/937257c3c9891bdf2d38

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

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

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

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

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

guest

回答1

0

ベストアンサー

https://teratail.com/questions/23619
↑こちらにもpagehideを使う話が出てきていますね。参考になるかもしれません。

ページ遷移系一般についてですが、遷移のイベントを拾って非同期な処理を行おうとすると、処理完了前にページ遷移が起きてしまい、安定して処理が行えないという問題はよく発生します。

また、pagehideは「閉じたあとに発生」すると前述の記事にあったので、この時点で通信は行えない状態なのかもしれません。

苦肉の策としては、リンククリックを拾って非同期処理完了後、location.hrefなどを使って擬似的に遷移する...などの方法ですかね。

投稿2019/04/30 19:44

編集2019/04/30 19:44
otolab

総合スコア767

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

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

poteto4401

2019/05/01 06:25

そちらも以前確認しました。 やはりシンプルに実装できないものなのですね。。 ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問