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

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

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

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

Q&A

2回答

12335閲覧

非同期実行される関数のコールバック

chijan

総合スコア24

JavaScript

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

0グッド

0クリップ

投稿2015/11/11 11:31

http://danml.com/download.html
にあるdownload.jsを導入して使える関数downloadの処理が終わったことを判定したいです。

downloadにより書き込んでから、書き込んだファイルに関して処理を実行したいのです。

ブラウザはFirefox41.0.2です。OSはWin8.1とMacOSXです。

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

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

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

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

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

guest

回答2

0

ダウンロード機能はJavaScriptで制御してなくて、ブラウザのダウンロード機能を使ってダウンロードさせているのでダウンロード完了を判定する事は出来ません。

(2015/11/11 22:15追記)
ダウンロード監視をサーバサイドに持ってきて良いのならば、navigator.serviceWorker があります。
miyabi-sun さんが紹介されたような polling が主流でしたが、こちらもダウンロード官僚の監視はサーバサイドで行います。
クライアントサイドだけで完結する方法としては拡張機能に可能性がありますが、こちらは詳しくありません。

Re: chijan さん

投稿2015/11/11 11:47

編集2015/11/11 13:16
think49

総合スコア18189

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

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

0

think49さんの言うようにそのライブラリでは実装出来ません。
そもそもダウンロード完了というイベントがブラウザにはないのでお手上げです。

…と思いつつも探したら、代替手段による迂回策はあるようです。

http://d.hatena.ne.jp/nabehiro/20140208/1391850498
http://qiita.com/hidakatsuya/items/1b970d17ecb016dddec7

1.ブラウザで上記ダウンロード処理を開始した後に、毎秒クッキーの特定パラメータを監視
2.サーバーサイドでDLが終わるタイミングでクッキーの特定パラメータのフラグを変更
3.クッキーのパラメータが変更された事を検知

クッキーの扱いはそのWebページを表示した瞬間に決定するとの事を聞いたので
この迂回策が使えるブラウザ、使えないブラウザがあるかもしれません。
とはいえ、ブラウザやOSが固定されているので何とかなりそうな気がします。
頑張ってください!

投稿2015/11/11 12:53

miyabi-sun

総合スコア21194

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

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

chijan

2015/11/12 06:35

回答ありがとうございます。 http://d.hatena.ne.jp/nabehiro/20140208/1391850498 はクッキーを用いていますが、これはlocalStorage.getItemでそのまま代用できるのでしょうか? いじりたいXMLファイルのサイズゆえlocalStorage.setItemを用いて hoge = (new XMLSerializer()).serializeToString(xmlRoot); localStorage.setItem(key,hoge); としてローカルストレージに置いています。 hoge,keyはグローバル変数で、xmlRootはXMLファイルオブジェクトです。 d3.xml("data.xml", "application/xml", function(error, xmlRoot){ })の内部で処理しております。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問