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

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

新規登録して質問してみよう
ただいま回答率
85.49%
jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

3回答

1663閲覧

jQuery: リダイレクトしたページで1.1秒後に1回だけ今いるページをリロードさせたい

rails_ruby

総合スコア87

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2019/06/02 13:16

実現したいこと

リダイレクト後に一回だけリロードをしたい。

できたところ

リダイレクトしたい際にアラートが表示され、1秒後に消える処理まで実装することができたが、その後にリロードする処理が発火しなくて困っています。

jquery

1 $(function(){ 2 setTimeout("$('.alert').fadeOut('slow')", 1000); 3 setTimeout("$('.alert').reload()", 1100); 4 });

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

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

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

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

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

yambejp

2019/06/03 02:22

リロードしたときは一度フェードアウト、 リロードでないときは2度フェードアウトするという仕様で良いですか?
rails_ruby

2019/06/03 02:46

実装したいこととしては、投稿をポスト後にトップ画面にリダイレクトするようにしており、リダイレクトしたトップ画面で「投稿に成功しました」といるようなアラートが表示される使用になっています。 その際に、アラートが1秒後にフェードアウトするように実装しているのですが、アラートがフェードアウトした際に微妙な隙間が空いており、その隙間を手動でリロードすると治るので自動化したいしたいなという思いから質問させていただきました。 なので、1秒後にアラートが消えたのちに0.1秒後にリロードを一回だけさせたいなと考えています。
guest

回答3

0

第1引数が関数になってないからではないかなと。
下記のように変更して試してみてください(未検証です。要は関数にしましょうということですね)。

js

1$(function(){ 2 setTimeout(function() { 3 $('.alert').fadeOut('slow'); 4 }, 1000); 5 setTimeout(function() { 6 location.reload(); 7 }, 1100); 8}); 9

ただ「リロード」であれば、リロード後にまた上記の処理が発生するので、
WebStorageにフラグ1つ持っておいて「1回目のアクセス」と「2回目以降のアクセス」を判定する処理は必要に思います。

投稿2019/06/02 13:30

編集2019/06/02 13:34
m.ts10806

総合スコア80850

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

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

rails_ruby

2019/06/02 13:33

リロード処理については、たった今実装できたのですが、おっしゃる通り、ただリロードさせるとリロード後に再度リロードされてしまいます。 WebStorageについてあまりに詳しいくないのでどのように判定処理を行えば良いかご教示いただけないでしょうか?アドバイスだけでもいただけると幸いです。
m.ts10806

2019/06/02 13:35

回答にリンクつけていますが、それを読まれたうえではどうでしょうか。 すごく簡単に説明すると「ブラウザにドメインごとにデータを保存する」機能です。
rails_ruby

2019/06/02 13:54

何と無くイメージをつかめました。 var ABC = localStorage.getItem( "DATA" ); こんな感じにして、ifで判定してあげればできそうな気がしますが、リロードのタイミングでlovalstrageに追加する方法が思いつかないので色々と試してみます。
m.ts10806

2019/06/02 14:09 編集

※lovalstrage → localStorage そうですね。フラグのような使い方をすると良いです。 >リロードのタイミングでlovalstrageに追加する方法 リロード直前にsetItemすれば良いだけの話と思うのですが如何でしょうか。 あと・・・WebStorageにはlocalStorageとsessionStorageの2種類があります。 もし「半永久的に」としたいのでしたら明示的に削除しないと残り続けるlocalStorageを使い、 「ブラウザが閉じられるまでの間」としたいのでしたらsessionStorageを採用します。
guest

0

ベストアンサー

イマイチ仕様が理解できないのですが

  • alertが表示されて1秒後にフェードアウト
  • 0.1秒後に1回だけリロードする

を実現するならこんな感じ

javascript

1<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script> 2<script> 3var flg=window.performance.navigation.type; 4$(window).on('pageshow', function(){ 5 $('.alert').show().delay(1000).fadeOut('slow').delay(100).queue(function(){ 6 if(flg==0){ 7 flg=2; 8 location.reload(); 9 } 10 $(this).dequeue(); 11 }); 12}); 13</script> 14<div class="alert">alert</div> 15test

でも、この仕様は当然2回フェードアウトが発生しますが意図がよくわかりません

投稿2019/06/03 08:26

yambejp

総合スコア114767

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

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

rails_ruby

2019/06/04 15:46

ご教示いただきありがとうございます。 おっしゃる通り、仕様としてはおかしいのですが一時的に退避方法としてご質問させていただきました。 そのため、今後練習開発を進めていく中で解決方法を探っていきたいと思います。
guest

0

javascriptにあるlocation.reload() を使うのはどうでしょう?
// 1.1秒に一回リロード
setTimeout("location.reload()",1100);

投稿2019/06/02 13:28

Kazuyuki-T0806

総合スコア326

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

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

miyabi_takatsuk

2019/06/02 15:47

それだと、リダイレクト後に、”一回だけリロード”の要件が満たせません。 それだと、ページアクセス毎に、1.1秒後にリロードを繰り返してしまいます。
Kazuyuki-T0806

2019/06/03 07:33 編集

その通りですね mts10806の回答が適切だと思うのでこちらは削除申請を致します
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問