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

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

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

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

TypeScript

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

Q&A

解決済

4回答

444閲覧

多次元配列をflat使わずに一層にしたい。

yuki_90453

総合スコア326

JavaScript

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

TypeScript

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

0グッド

1クリップ

投稿2022/05/24 09:45

概要

下記のように出力結果が、多次元配列に処理があります。
出力結果をflatにしたいのすが、mapの戻り値をスプレッド構文で記述して一層の配列にすることはできないでしょうか?

flat関数を使用することでフラット化が出来ますが、スプレッド構文を戻り値として指定してフラット化出来ないでしょうか?

javascript

1 const sample = Array(3).fill(Array(3).fill(0)) 2 const res = sample.map(innerArray=>{ 3 return innerArray.map(num =>{ 4 // この部分をスプレッド構文で返したいがエラーになる。 5 // return ...(num + 3) 6 return num + 3 7 }) 8 })
// 実際の戻り値 [Array(3), Array(3), Array(3)] // やりたい結果 [3, 3, 3, 3, 3, 3, 3, 3, 3]

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

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

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

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

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

maisumakun

2022/05/24 10:53

なぜ「flatを使わずに」行う必要があるのでしょうか。
yuki_90453

2022/05/24 10:54

私の環境node v14.16.1では使えないようです。
guest

回答4

0

flatがない時代はこんな感じで書いてたような。
[].concat.apply([],res)

投稿2022/05/25 01:17

Lhankor_Mhy

総合スコア36140

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

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

0

javascript

1const res=[[1,2,3],[4,5,6],[7,8,9]].reduce((x,y)=>x.concat(y)); 2とか 3const res=[[1,2,3],[4,5,6],[7,8,9]].reduce((x,y)=>(x.push(...y),x));

投稿2022/05/25 00:55

編集2022/05/25 00:57
yambejp

総合スコア114968

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

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

0

こんなんでいい?

javascript

1const sample = Array(3).fill(Array(3).fill(0)) 2 3const res = sample.reduce((pre, cur)=>{return pre.concat(cur.map(num=>{return num + 3}))}, []) 4 5console.log(res)

投稿2022/05/24 12:08

takasima20

総合スコア7460

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

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

0

ベストアンサー

スプレッド構文を戻り値として指定してフラット化出来ないでしょうか?

この形で実行することはできません。

いちばん内側の関数はもともと1つの値しか返しませんので、(仮に文法が許したとしても)スプレッドは意味が通りません。

投稿2022/05/24 10:55

maisumakun

総合スコア145201

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問