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

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

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

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

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

Q&A

解決済

1回答

377閲覧

Javascript 引数の呼び出しのタイミングについて

kanemichi

総合スコア10

JavaScript

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

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

0グッド

0クリップ

投稿2020/07/20 09:55

単純な平均値を計算したい

ある配列の要素の平均値を計算したいのですが、

[関数呼び出し]の記述順序、[console.log()]の記述順序などが理解できていません。undefinedが出力される場合と、逆にそうでない場合があります。
以下にコードを示します。

コード let data = [59, 39, 100, 2, 15, 40, 84, 97]; let ave; // 平均値を定義 function calc_ave(data) { //平均値を計算する関数 let total = 0; //ローカル定義 for(let i = 0; i < data.length; i++) { //繰り返し処理 total = total + data[i]; } let ave = total / data.length; //繰り返し処理が終わったら平均値の計算 console.log(ave); //54.5と表示...これは普通に、一行目上の結果が出力されている? return ave; } console.log(ave); //undefinedと出力される // 関数calc_aveを実行する ave = calc_ave(data); //dataを渡す & [59, 39, 100, 2, 15, 40, 84, 97];が展開された状態。 // 平均値を書き出し console.log(ave); //ここに書くと「54.5」上ではundefined......

御教授のほどお願いいたします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

変数が参照される順番の問題です。

Javascript

1 2let data = [59, 39, 100, 2, 15, 40, 84, 97]; 3let ave; // 平均値を定義 **1番目** 4**↑ ここで変数aveがあると定義** 5 6** この時点では関数は呼び出されません ** 7** 呼び出すためには calc_ave(引数)とする必要があります。** 8function calc_ave(data) { //平均値を計算する関数 9 let total = 0; //ローカル定義 10 for(let i = 0; i < data.length; i++) { //繰り返し処理 11 total = total + data[i]; 12 } 13 14 let ave = total / data.length; //繰り返し処理が終わったら平均値の計算 15 console.log(ave); // **4番目** 16 return ave; 17} 18 19console.log(ave); //undefinedと出力される  **2番目** 20**↑ ここではまだ変数aveは let ave; のままで何も定義されていない。のでundefined ** 21 22 23// 関数calc_aveを実行する 24ave = calc_ave(data);  **3番目** 25**↑ここで初めて、変数ave は引数dataをもつ関数であると定義され** 26** calc_ave(data); が呼び出されています。** 27 28// 平均値を書き出し 29console.log(ave); // **5番目** 30**変数ave は引数dataをもつ関数であると定義されているため 54.5と表示**

投稿2020/07/20 10:17

Jon_do

総合スコア1373

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

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

kanemichi

2020/07/20 10:33

ご丁寧に、ご回答有難うございます! 関数を呼び出した後に、4番目のconsole.logが出力される、ということですね。 ここの順番自体、理解できていなかったようです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問