
お世話になります。
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.3
- 回答日時:
javascriptもgifの描画もブラウザ側の処理です
ブラウザが処理(描画)出来なければ止まる
「処理している間も動かしたい!」
と言う気持ちも分からなくもないので少しだけ
#1さんの回答の捕捉になるのですが……
Ajaxを使用して処理をサーバーに投げる
(ブラウザに処理させない)
もしくは処理を複数回に分けて分散させる
(一度にまとめて処理しない)
知らない技術を出されて難しいとは思いますけれど……
自分にはこれくらいしか思いつきませんです
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ftp 同時複数接続の負荷テスト...
-
Javaでのデバッグコード削除
-
Odbcオブジェクトの解放の方法
-
再度、スレッドが実行中かどう...
-
ServletContextLisntener#conte...
-
表示待ち時間に「処理中...」の...
-
ExcelVBA で文字列の特定の文字...
-
[Java] while(true)の意味
-
Javaプログラムからポップアッ...
-
C#で別スレッドの終了を知りたい
-
「タイプ初期化子が例外をスロ...
-
エクセルVBAで、条件に一致する...
-
変数名の付け方
-
private static という変数の修飾
-
コマンドプロンプト実行後に画...
-
java eclipse 型に解決できません
-
c++,ある関数のクラスから別の...
-
String.containsの反対機能はあ...
-
C#において、同じインスタンス...
-
readLine()ではじめから読み直...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Javaプログラムからポップアッ...
-
tryの終了
-
Javaでのデバッグコード削除
-
BLOB型の画像データを表示したい
-
ラジオボタンの選択判定
-
doGetとdoPostの違い
-
Tomcat高負荷時の設定について
-
C#で別スレッドの終了を知りたい
-
C#の処理をリアルタイムに表示...
-
アコーディオンメニューをアン...
-
重たい処理のタイムアウト強制終了
-
JavaScriptからJAVAクラスを呼...
-
ftp 同時複数接続の負荷テスト...
-
[Java] while(true)の意味
-
数値の定数を付ける時
-
JSP、サーブレットの初期処理
-
ExcelVBA で文字列の特定の文字...
-
Tomcatのスレッドを破棄する方法
-
ラベルの表示までが異常に遅い...
-
onBlurとonFocusの処理順序につ...
おすすめ情報