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

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

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

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

jQuery

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

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

Q&A

解決済

2回答

232閲覧

不定数の画像を全て読み込んだことを感知する非同期処理について/Javascript

bravo

総合スコア14

JavaScript

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

jQuery

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

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

0グッド

0クリップ

投稿2019/02/13 04:30

前提・実現したいこと

javascriptで画像を読み込んだのち、その画像のwidthと元のデータを使用して処理を行い、すべてが終了した時点で他の処理を行いたいと思っています。
色々調べてはみたのですが、onloadで読み込んだ画像自体の情報と、その画像が何番目のデータのものなのかを共に扱うことがどうしてもできません。

該当のソースコード

javascript

1//dataに画像のurlやその他のデータが格納されています 2 3function test(data) { 4 var count = 0; 5 for (i = 0; i < data.length; i++) { 6 var image = new Image(); 7 image.src = data[i].ImageUrl; 8 image.onload = function () { 9 console.log(i+'番目のデータの画像の横幅は"+image.width); 10 ++count; 11 if (count == data.length) { 12 console.log('全て終了'); 13 } 14 } 15 16 } 17 } 18 19$.when(test()).done( 20//test終了後に処理 21)

結果として横幅は正しいものがとれるのですが、iの部分が例えばdataが10個あるとしたら全て11になってしまします。
非同期で処理してるために、一番最後のiが取得されているためだと思います。
かといってcountをとったとしても、それは読み込みが完了した順であってデータの順番ではなくなってしまいます。

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

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

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

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

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

guest

回答2

0

非同期で処理してるために、一番最後のiが取得されているためだと思います。

ES6が使える環境なら、iletで宣言するだけでこの問題を回避できます。

javascript

1for (let i = 0; i < data.length; i++) {

使えないときは、ループ1回毎に無名関数を切るという手段があります。

for (var j = 0; j < data.length; j++) { (function(i){ // ループの中身はそのままでOK })(j); }

投稿2019/02/13 04:34

maisumakun

総合スコア145184

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

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

miyabi-sun

2019/02/13 05:19

対応状況よく見たら12/14になってて、 「for/for-in loop iteration scope」関係は非対応…今回のように関数で包んで持ち出すとアウトだそうで駄目みたいですね。
guest

0

ベストアンサー

無名関数で包んで引数定義しておき、
Function.ptototype.bindで固定してしまうのはどうでしょうか?

JavaScript

1image.onload = (function (i) { 2 console.log(i+'番目のデータの画像の横幅は"+image.width); 3 ++count; 4 if (count == data.length) { 5 console.log('全て終了'); 6 } 7}).bind(null, i);

投稿2019/02/13 04:40

miyabi-sun

総合スコア21158

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問