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

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

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

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

Q&A

解決済

4回答

926閲覧

javascriptの連想配列の値を条件付きで抽出したい

asahiko123

総合スコア43

JavaScript

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

0グッド

0クリップ

投稿2021/10/21 05:21

編集2021/10/21 13:59

前提・実現したいこと

Javascriptの以下の連想配列から、style.typeの値が一致するtimeの値を配列にして
取得したいのですが、やり方がわからないので質問させて頂きました。

該当のソースコード

const group=[ { stuff: {name: 'A'} time: 60 style: {type: 'typeA'}}, { stuff: {name: 'A'} time: 120 style: {type: 'typeB'}}, { stuff: {name: 'A'} time: 83 style: {type: 'typeC'}}, { stuff: {name: 'B'} time: 257 style: {type: 'typeB'}}, { stuff: {name: 'B'} time: 120 style: {type: 'typeD'}}, { stuff: {name: 'B'} time: 66 style: {type: 'typeA'}} ]

試したこと

const groupBytime=group.map(x=>x.time);

map関数を使うと[60, 120, 83, 257, 120, 66]という結果が得られましたが、
これをstyle.typeが'typeA'のtimeの配列[60,66]、'typeB'のtimeの配列[120,257]...といったように出力を分けたいです。似たような例を見つけられなかったので質問させて頂きました。

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

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

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

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

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

yambejp

2021/10/21 06:00

const group={・・・}の部分はconst group=[・・・]にしないと成立しません
asahiko123

2021/10/21 14:09

ご指摘ありがとうございます。 修正しました。
guest

回答4

0

こういうときはlodashというのを使うといいと、このサイトで昔教わったので。

javascript

1const groupBytime = _(group).groupBy('style.type').mapValues(ary => _.map(ary, 'time')).value();

???? CodePenで動かしてみた。

投稿2021/10/21 06:52

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

asahiko123

2021/10/21 14:20

このライブラリ便利そうですね.. 知らなかったので情報ありがとうございます。
退会済みユーザー

退会済みユーザー

2021/10/21 14:35

便利ですよ???? ???? https://lodash.com/ 特に今回使った groupBy https://lodash.com/docs/4.17.15#groupBy は今回のようなグループ化するときに便利です。 groupBy の引数に 'style.type' というドット区切りの文字列を与えれば、各オブジェクトの対応する階層のプロパティの値をグループ化のキーにしてくれるというのもナカナカ気が利いてます。
guest

0

javascript

1const group=[ 2 {stuff:{name: 'A'},time:60 ,style:{type:'typeA'}}, 3 {stuff:{name: 'A'},time:120,style:{type:'typeB'}}, 4 {stuff:{name: 'A'},time:83 ,style:{type:'typeC'}}, 5 {stuff:{name: 'B'},time:257,style:{type:'typeB'}}, 6 {stuff:{name: 'B'},time:120,style:{type:'typeD'}}, 7 {stuff:{name: 'B'},time:66 ,style:{type:'typeA'}}, 8]; 9const types=[...new Set(group.map(x=>x.style.type))]; 10console.log(types); 11const result=types.map(x=>group.filter(y=>y.style.type==x).map(x=>x.time)); 12console.log(result);

投稿2021/10/21 06:06

yambejp

総合スコア115010

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

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

asahiko123

2021/10/21 14:15

回答ありがとうございます。 こんなに短く記述できるとは、目から鱗でした。
guest

0

groupが配列だとすると、reduce()を使って下のようなコードで { タイプ名: [time値, ...], タイプ名: [time値, ...], ...} というオブジェクトができます。

js

1group.reduce((obj, current) => { 2 (obj[currnt.style.type] ??= []).push(current.time); 3 return obj; 4}, {});

for of で回したほうがわかりやすいコードかもしれません。

投稿2021/10/21 05:50

編集2021/10/21 06:10
int32_t

総合スコア21012

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

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

0

ベストアンサー

もう少しいい方法があるかと思いますが、reduceで一度style.typeごとに分けて、その後でmaptimeの値だけまとめて返したらいけると思います。

js

1const result = group.reduce((acc,cur) => { 2 const target = acc.findIndex((e) => e.type === cur.style.type); 3 if(target >= 0) { 4 acc[target] = { 5 type: acc[target].type, 6 values: [...acc[target].values, cur.time] 7 } 8 } else { 9 acc.push({ 10 type: cur.style.type, 11 values: [cur.time] 12 }) 13 } 14 return acc; 15}, []).map((d) => d.values); 16 17console.log(result);

出力

[ [ 60, 66 ], [ 120, 257 ], [ 83 ], [ 120 ] ]

投稿2021/10/21 05:34

nekoniki

総合スコア2411

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

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

asahiko123

2021/10/21 14:17 編集

reduceとfindを使ってできないか考えていたので、findIndexはなるほどと思いました。自分が考えていた形に一番近いというところでベストアンサーにさせていただきます。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問