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

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

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

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

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

Q&A

解決済

3回答

936閲覧

mapで配列を返したい

yuki_90453

総合スコア326

JavaScript

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

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

0グッド

0クリップ

投稿2020/09/01 06:31

#やりたい事

const list = [ ['aaa','bbb','ccc'], ['aaa','bbb','ccc'], ['aaa','bbb','ccc'], ] const hoge = list.map((item)=>{ return item }) hoge // ['aaa','bbb','ccc','aaa','bbb','ccc','aaa','bbb','ccc']としたい。

二次元配列の変数をmapを使用して、一般的に配列を出力したいです。
必ずmapを使用して行いたいのですが、どのように処理すれば二次元配列ではなく、一般的な配列で出力出来ますか?

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

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

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

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

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

maisumakun

2020/09/01 06:43

「必ずmapを使用して行いたい」のはなぜでしょうか? (mapはコードに入っているけど、それが「全く同じ内容の配列を返す、ほぼ無意味な操作」であっても問題ないのでしょうか?)
guest

回答3

0

map で実装を考えることが間違いです。

javascript

1const hoge = list.flat(); 2console.log(hoge); 3// ["aaa", "bbb", "ccc", "aaa", "bbb", "ccc", "aaa", "bbb", "ccc"]

map を使う場合、forEach と同じ使い方になり、返却値が無意味になってしまいます。

javascript

1const hoge2 = [] 2for ( ary of list ) { hoge2.push(...ary) }; 3console.log( hoge2 ); 4 5const hoge3 = [] 6list.forEach( ary => hoge3.push(...ary) ); 7console.log( hoge3 ); 8 9const hoge4 = [] 10list.map( ary => hoge4.push(...ary) ); 11console.log( hoge4 );

投稿2020/09/01 06:38

編集2020/09/01 07:15
AkitoshiManabe

総合スコア5434

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

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

0

ベストアンサー

flat一択でしょうけど、配列をいじくりまわしたならreduceでもできます

javascript

1const hoge=list.reduce((x,y)=>(x.push(...y),x));

よく考えたらこれでも

const hoge=[].concat(...list);

投稿2020/09/01 06:53

編集2020/09/01 07:06
yambejp

総合スコア116732

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

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

AkitoshiManabe

2020/09/01 07:03

reduce は色々弄れますね。スプレッド構文を用いてpushする箇所を古典な concat にしたパターン const hoge = list.reduce((x,y)=>x.concat(y),[]);
yambejp

2020/09/01 07:06

いろいろ考えたんですがmapが必要になるケースが考えつかないですね・・・
guest

0

先にflat()を使ってからmapを使うのはどうですか?
※この場合mapを使う意味がありませんが、「必ずmapを使用して行いたい」とのことなので・・・

javascript

1const list = [ 2 ['aaa','bbb','ccc'], 3 ['aaa','bbb','ccc'], 4 ['aaa','bbb','ccc'], 5] 6const hoge = list.flat().map((item)=>{ 7 return item 8}) 9console.log(hoge); 10// -> ["aaa", "bbb", "ccc", "aaa", "bbb", "ccc", "aaa", "bbb", "ccc"]

投稿2020/09/01 06:35

編集2020/09/01 07:20
nekoniki

総合スコア2411

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問