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

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

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

foreachは、List・Collection・Arrayといったデータ構造の各要素に対して繰り返し処理を実行するために扱われる、制御構造の構文です。

JavaScript

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

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

Q&A

4回答

1003閲覧

JavaScriptでforEachを使用して配列の要素を足し算し、変数に入れて使いたいが理想とした結果が出ません、、

hiroki17

総合スコア4

foreach

foreachは、List・Collection・Arrayといったデータ構造の各要素に対して繰り返し処理を実行するために扱われる、制御構造の構文です。

JavaScript

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

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

0グッド

2クリップ

投稿2022/06/05 02:08

let arr = [1, 2, 3, 4]; let sum = 0; let arr2 = arr.forEach((n) => { return (sum += n); }); console.log(arr2); 僕の期待する結果は // 11ですが // undefinedで帰ってきます、、、 僕の頭の中は            ↓に1,2,3,4と1つずつ呼び出され let arr2 = arr.forEach((n) => { return (sum += n); ↑ ここで sum += n (0 += 0 + 1 ) (1 += 1 + 1 ) (2 += 1 + 2 ) }); のイメージですが何が違うのでしょうか?? すみませんお願いいたしますm(_ _)m

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

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

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

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

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

hoshi-takanori

2022/06/05 02:32

やりたいことは reduce でできるかも。 let sum = arr.reduce((a, n) => a + n, 0);
hiroki17

2022/06/08 08:02

気づいてなくてすみません>< 回答ありがとうございますm(_ _)m
guest

回答4

0

一般に加算を繰り返して結果をえる場合reduceなどを利用しますね

javascript

1let arr = [1, 2, 3, 4]; 2let sum1 = 0; 3arr.forEach(x=>sum1+=x); 4console.log(sum1); 5let sum2 = arr.reduce((x,y)=>x+y); 6console.log(sum2);

投稿2022/06/06 01:04

yambejp

総合スコア114812

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

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

0

MDN で forEach の説明をみると

返値

undefined です。

とあります。なので質問にあるような let arr2 = arr.forEach(・・・ というように、forEach(・・・) の返す値を変数に入れるコードを書くことはまず無いです。

ちなみに配列のメソッドで引数にコールバックを取るものは forEach の他にもありますが、reduceを使うと、以下のようにメソッドの返す値が配列要素の合計になるように書けます。

javascript

1const arr = [1, 2, 3, 4]; 2const sum = arr.reduce((s, e) => s + e); 3 4console.log(sum); // =>10

投稿2022/06/05 03:26

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

hiroki17

2022/06/05 11:53

ご丁寧にありがとうございます! 上記の書き方調べてみます>< ありがとうございますm(_ _)m
guest

0

僕の期待する結果は
// 11ですが
// undefinedで帰ってきます、、、

下記コードでは合計値は「10」と出力されます。

javascript

1const arr = [1, 2, 3, 4]; 2let sum = 0; 3 4arr.forEach(n => sum += n); 5 6console.log(sum); 7# 10

投稿2022/06/05 02:27

meg_

総合スコア10580

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

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

hiroki17

2022/06/05 11:52

ごめんなさいそもそも計算ミスしてますね、、、
guest

0

足されている変数は「sum」であるため、sumをconsole.logで出力すれば期待されている動作になるのではないでしょうか!
また、forEachは返り値がないという性質を持っているため、代入しているarr2はundefinedになるのだと思います!

投稿2022/06/05 02:18

raratyurara

総合スコア45

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

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

raratyurara

2022/06/05 02:20

ですので、現在 return (sum += n); と記述されておりますが、forEachのみで実装するのであれば sum += n; のみで実現できるかと思います!
hiroki17

2022/06/05 02:28

ご丁寧な回答ありがとうございますm(_ _)m 変数に代入して実現するにはforEachは使えない認識で大丈夫でしょうか?><
raratyurara

2022/06/05 02:32

ありがとうございます! そうですね! forEachでは変数に代入できないという認識でお間違いないです! また、変数に代入したいのであれば、forEachより少し複雑ですが「reduce」というメソッドを使うことがおすすめです! (reduceを使えば sum = arr.reduce(~~~~~) といった形でスマートに記述できます!)
hiroki17

2022/06/05 11:52

ご丁寧にありがとうございます>< 使い方調べてみますねm(_ _)m
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問