お世話になります。
javascript で重い処理中のプログレス(アニメーションgif)表示について教えてください。
やりたいことは以下です。
====================================
1.重い処理の前にプログレス(アニメーションgif)表示
2.重い処理開始
3.プログレス(アニメーションgif)非表示
[sample.html]
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7 …
<script type="text/javascript">
$(function() {
$('#btn').click(function() {
progressStart(); // プログレス(アニメーションgif)表示
func1(); // 重い処理開始
progressEnd(); // プログレス(アニメーションgif)非表示
});
});
/**
* プログレス(アニメーションgif)表示
*/
function progressStart()
{
$('#prog').show();
}
/**
* プログレス(アニメーションgif)非表示
*/
function progressEnd()
{
$('#prog').hide();
}
/**
* 重い処理(とりあえず5秒)
*/
function func1()
{
var T = 5; //T秒待つ
var d1 = new Date().getTime();
var d2 = new Date().getTime();
while( d2 < d1+1000*T ){
d2=new Date().getTime();
}
return;
}
</script>
</head>
<body>
<form>
<input type="button" id="btn" value="開始" />
<div id="result"></div>
<img id="prog" src="img/loadinfo.gif"
alt="" style="display:none;" />
</form>
</body>
</html>
====================================
上記コードで試したのですが、
重い処理中はプログレス(アニメーションgif)が動かず固まったままです。。。
重い処理中もプログレス(アニメーションgif)を
動いたままにすることは可能なのでしょうか?
どなたかご教授いただければと思います。よろしくお願いいたします。
No.2
- 回答日時:
gifは処理止まりますね
キャッシュしても止まるんじゃないでしょうか?
HTML5の記述になるのですが
<progress max="100">現在、処理中……</progress>
などprogressタグを使用してみては如何でしょうか?
この回答への補足
回答ありがとうございます。
<progress max="100">現在、処理中……</progress>
を試してみましたがやはり画面が止まってしまいました。。。
No.3
- 回答日時:
javascriptもgifの描画もブラウザ側の処理です
ブラウザが処理(描画)出来なければ止まる
「処理している間も動かしたい!」
と言う気持ちも分からなくもないので少しだけ
#1さんの回答の捕捉になるのですが……
Ajaxを使用して処理をサーバーに投げる
(ブラウザに処理させない)
もしくは処理を複数回に分けて分散させる
(一度にまとめて処理しない)
知らない技術を出されて難しいとは思いますけれど……
自分にはこれくらいしか思いつきませんです
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- JavaScript 入力フォームの javascript で メールアドレスの正規チェックをを行い、ボタンをクリックして 2 2022/04/27 16:06
- HTML・CSS ボタンをクリックした時に、入力フォームのすぐ下部に、「入力欄が空白です」というテキストメッセージが表 1 2022/04/27 16:25
- JavaScript 1日1回引けるJavaScriptおみくじについて 1 2022/12/12 22:28
- JavaScript jQueryでのドラッグアンドドロップについて 1 2022/07/07 21:04
- JavaScript 画像の表示位置 3 2022/12/23 08:25
- JavaScript jqueryを使ったスムーススクロールのコードを書いたのですが、HTMLコード内にある、a butt 2 2022/04/14 10:59
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
- JavaScript jQueryでのドラッグアンドドロップについて 1 2022/07/30 09:10
- JavaScript コードレビューをお願いします。 1 2022/07/16 05:38
- JavaScript clear機能を失わずにファイルアップロード機能を作成したい 3 2023/06/10 16:12
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
JavaScriptからJAVAクラスを呼...
-
Javaアプリケーション実行の返...
-
tryの終了
-
JAVA ID重複処理
-
doGetとdoPostの違い
-
無限ループをわざと作って時計...
-
ExcelVBA で文字列の特定の文字...
-
データ未入力時のエラー処理が...
-
再度、スレッドが実行中かどう...
-
メソッドの再帰呼び出しについて
-
Thread.sleep()はすべてのスレ...
-
Javaプログラムからポップアッ...
-
バッチって何でしょうか?
-
数値の定数を付ける時
-
処理実行後、終了させないで最...
-
vba Sleep関数について教えてく...
-
switch文の中に、throws new Ex...
-
素数判定を再帰処理で
-
WPF C#でF10のイベント取得方法...
-
WaitForSingleObjectの復帰時間
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
tryの終了
-
数値の定数を付ける時
-
Javaでのデバッグコード削除
-
C#で別スレッドの終了を知りたい
-
[Java] while(true)の意味
-
Javaプログラムからポップアッ...
-
Tomcatのスレッドを破棄する方法
-
ラジオボタンの選択判定
-
JavaScriptからJAVAクラスを呼...
-
素数判定を再帰処理で
-
PHPでDB処理中にプログレスバー...
-
Javaアプリケーション実行の返...
-
WPF C#でF10のイベント取得方法...
-
doGetとdoPostの違い
-
switch文の中に、throws new Ex...
-
Tomcat高負荷時の設定について
-
ラベルの表示までが異常に遅い...
-
ExcelVBA で文字列の特定の文字...
-
JDBCでテーブルUPDATE後の再検...
-
SwingUtilities.invokeLater(ne...
おすすめ情報