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

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

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

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

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

Q&A

解決済

1回答

16108閲覧

jqueryのwhenとdoneの挙動

coinbura

総合スコア106

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

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

0グッド

2クリップ

投稿2015/09/06 07:26

以下のような形でwhenとdoneを使っています。

$(function(){
$.when(function(){
for(i=0; i>=5; i++){
色々処理
hoge[i] = 処理した値;
}
})
.done(function(){
$.ajax({
type: "get",
url: (test.php),
data: {"hoge" : hoge},
success: function(s){
document.write(s);
}
});
});
});

挙動として、whenが終わってからdoneが実行されると思っていたのですが、
「色々処理」の部分の動作が重いせいか、まったく動きません。

whenの部分でsetTimeoutを使って、処理が終わると思わしき時間待たせてからでないと、
リアルタイムで処理が終わってから動く、という挙動をさせることはできないのでしょうか?

ご教授いただければ幸いです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

質問の意図を汲み取れてないかもしれないのですが、
whenを使うときはDeferredとセットじゃないと動かないです。
次のようなソースであれば望んだ動作をすると思うのですが、いかがでしょう。
なお、setTimeoutは非同期感を出すために入れたダミーです。
最終的に色々処理が終わった後に$defer.resolve()してやることで
whenのdoneが実行されます。

JavaScript

1var $defer = new $.Deferred(); 2 3$.when( 4 $defer 5).done(function(){ 6 console.log('done'); 7}); 8 9var func = function(){ 10 console.log('func実行'); 11 window.setTimeout(function(){ 12 console.log('色々処理'); 13 return $defer.resolve(); 14 }, 3000); 15 return $defer.promise(); 16}; 17 18func();

ちなみに色々処理のところは非同期な処理($.ajaxなど)なんでしょうか。

投稿2015/09/06 09:03

編集2015/09/06 09:05
notable

総合スコア415

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

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

coinbura

2015/09/06 11:05 編集

>whenを使うときはDeferredとセットじゃないと動かない そうなんですね! 「$.ajaxや$.whenはDeferredインタフェースを備えている」との事なので、いらないと思っていました。 もう少し調べてみます。 「色々処理」は非同期な処理です。
notable

2015/09/06 12:26

仰るように$.ajaxはDeferredインターフェースを備えていますが、 各$.ajaxがwhenにDeferredオブジェクトを返してあげる必要があります。 質問にあるfor文内の色々処理で$.ajaxを実行し、それら全てが完了したときを whenに知らせるには、次のような書き方が出来ると思います。 試していないので違うところあるかもしれませんが… var deferArr = []; var hoge = []; for(i=0; i>=5; i++){ // whenに渡す$.ajaxを配列に入れる deferArr.push($.ajax({ // 色々処理 }).done(function(data){ hoge[i] = data; })); } // 配列に入れた各$.ajaxをwhenに渡す $.when.apply(null, deferArr).done(function(){ // すべて正常終了なら実行される $.ajax({ type: "get", url: (test.php), data: {"hoge" : hoge}, success: function(s){ document.write(s); } }); });
coinbura

2015/10/13 16:11

ありがとうございました。 返信が遅くなってしまい、すみませんm(__)m 教えていただいた方法を元に無事解決しました。 (なぜかdoneではできず、doneのところをsuccessに変更しました) 1ヶ月以上試行錯誤の末、本日やっと完成し、ただ今ちょっと興奮状態ですw 本当に感謝感謝です!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問