Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- mybatis
- SPC
- Python
- Sqoop
- tomcat
- mapreduce
- SQL
- Eclipse
- Express
- plugin
- IntelliJ
- MSSQL
- R
- SSL
- vaadin
- GIT
- react
- es6
- Kotlin
- NPM
- Android
- 보조정렬
- 공정능력
- Spring
- Java
- table
- hadoop
- window
- JavaScript
- xPlatform
Archives
- Today
- Total
DBILITY
javascript map reduce 본문
반응형
hadoop에 mapper,reducer를 생각하면 된다.java stream의 map,reduce도 있다.
입력요소를 x,출력요소를 y라 할때 x,y집합의 일대일대응 함수관계가 map
y요소가 하나일때를 reduce로 보면 된다.
map은 글자 그래도 요소마다 각각 적용할 수 있다.
reduce는 결과가 요소집합에 대해 하나다. summary를 상상하자. 끝.
이거 보고 광고 한번 안 누른 이는 삼대가 재수가 없을지어다!ㅋㅋ
다음과 같은 기본 배열 데이터가 있다.
var data = [
{
id: 0,
title: '해운대LCT - 가운데 라인 로얄층으로 위아래 우연히 공인중개사가 소개함',
price: 30.5
},
{
id: 1,
title: '대장동 헐값 분양아파트 - 퇴직금도 못받고 아빠가 미안해',
price: 15.2
},
{
id: 2,
title: '내곡동1334평. 기억에 겸손하고 팔에감어를 신는 분만! 애완동물 불가능 🐶',
price: 34.8
}
]
동일데이터를 저장하면서 object내의 id값은 원본 데이터의 최대값 이후부터 부여하려고 한다. 다음과 같은 결과를 원한다.
var copyData = [
{
id: 0,
title: '해운대LCT - 가운데 라인 로얄층으로 위아래 우연히 공인중개사가 소개함',
price: 30.5
},
{
id: 1,
title: '대장동 헐값 분양아파트 - 퇴직금도 못받고 아빠가 미안해',
price: 15.2
},
{
id: 2,
title: '내곡동1334평. 기억에 겸손하고 팔에감어를 신는 분만! 애완동물 불가능 🐶',
price: 34.8
},
{
id: 3,
title: '해운대LCT - 가운데 라인 로얄층으로 위아래 우연히 공인중개사가 소개함',
price: 30.5
},
{
id: 4,
title: '대장동 헐값 분양아파트 - 퇴직금도 못받고 아빠가 미안해',
price: 15.2
},
{
id: 5,
title: '내곡동1334평. 기억에 겸손하고 팔에감어를 신는 분만! 애완동물 불가능 🐶',
price: 34.8
}
]
reduce를 이용해 원본데이터에서 id의 최대값을 구하고(accumulator에 currentValue를 누산[임시저장]), map을 이용해 id값을 각각 증가시켜 주면 된다.
let copyData = [...data]
let maxId = data.reduce((accumulator,currentValue)=>{
return Math.max(accumulator,(currentValue.id));
},0);
let rsData = copyData.map((v)=>{
v.id=++maxId;
return v;
});
console.log(rsData);
copyData = [...data,...copyData];
console.log(copyData);
https://developer.mozilla.org/ko/docs/Web/JavaScript/Reference/Global_Objects/Array/map
https://developer.mozilla.org/ko/docs/Web/JavaScript/Reference/Global_Objects/Array/Reduce
반응형
'front-end & ui > javascript' 카테고리의 다른 글
javascript optional chaining , nullish coaleasing (0) | 2022.03.30 |
---|---|
javascript Object.assign (0) | 2022.02.15 |
javascript es6 promise (0) | 2021.12.22 |
javascript es6 import/export for variable,function,class (0) | 2021.12.22 |
javascript es6 destructuring assignment ( 구조분해할당 ) (0) | 2021.12.22 |
Comments