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

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

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

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

JavaScript

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

例外処理

例外処理(Exception handling)とは、プログラム実行中に異常が発生した場合、通常フローから外れ、例外として別の処理を行うようにデザインされたプログラミング言語構造です。

配列

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

Q&A

解決済

2回答

560閲覧

JavaScriptにてforEachを使い、該当条件が一致した場合ListAのデータをListBに入れる処理を書いたものの、例外処理の書き方がわかりません。

hololiveyukimin

総合スコア5

foreach

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

JavaScript

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

例外処理

例外処理(Exception handling)とは、プログラム実行中に異常が発生した場合、通常フローから外れ、例外として別の処理を行うようにデザインされたプログラミング言語構造です。

配列

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

0グッド

0クリップ

投稿2021/06/11 03:13

連想配列Aと連想配列Bがあり、JavaScriptにてforEachを使って該当条件に一致する場合は連想配列Aの情報を連想配列Bに追加するというコードを書いています。書いたコードを試したところ想定通り動きはしたのですが、下記のエラーが起きました。
確かめてみたところ、ListA側のsobaSeqに対応するListBのitemSeqが無いためのエラーだとわかりましたが、対応する番号がなかった場合にスキップする処理がうまくできませんでした。どのように書けばいいのでしょうか?

発生している問題・エラーメッセージ

予期しないエラーが発生しました。TypeError: Cannot set property 'itemName' of undefined

該当のソースコード

JavaScript

1let ListA = [ 2 { itemName: 'どうのつるぎ', sobaSeq: 1}, 3 { itemName: 'かわのたて', sobaSeq: 3}, 4 { itemName: 'かわのぼうし', sobaSeq: 2 }, 5 { itemName: 'かわぼう', sobaSeq: 4 }, 6 ] 7 8let ListB = [ 9 {totalPrice:200,itemSeq:1}, 10 {totalPrice:1500,itemSeq:2}, 11 {totalPrice:1523,itemSeq:3} 12]; 13 14ListA.forEach((a) => { 15 const name = a.itemName; 16 const target =ListB.find((b) => b.itemSeq === a.sobaSeq); 17 target.itemName = name; 18 }) 19 20console.log(ListB); 21

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

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

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

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

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

guest

回答2

0

ベストアンサー

ListBをforEachすればいいのでは?

javascript

1/* 修正前 2ListB.forEach(x=>(x.itemName=ListA.find(y=>y.sobaSeq==x.itemSeq).itemName,x)); 3*/ 4ListB.forEach(x=>x.itemName=ListA.find(y=>y.sobaSeq==x.itemSeq).itemName); 5console.log(ListB);

※すみません、ちょっと直しました

投稿2021/06/11 04:09

編集2021/06/11 04:20
yambejp

総合スコア116724

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

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

hololiveyukimin

2021/06/11 04:15

ありがとうございます。ご指摘のコードで対応できました。
guest

0

スキップするなら、if文でtargetが無いなら処理しないようにすれば良いです

投稿2021/06/11 03:51

zushi0905

総合スコア683

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

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

hololiveyukimin

2021/06/11 04:16

回答ありがとうございます。ご指摘のコードでも実行できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問