일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
- server
- 트랜잭션
- 블록체인
- 네트워크
- MySQL
- Programming
- solidity
- Docker
- NFT
- 이더리움
- web3
- ERC20
- 제어의역전
- truffle
- ethers
- geth
- git
- ERC165
- 솔리디티
- web3.js
- blockchain
- Ethereum
- erc721
- web
- 스마트 컨트랙트
- JavaScript
- tcp
- Python
- erc
- github
- Today
- Total
멍개의 연구소
javascript arrow function과 array.prototype의 조합 본문
오늘은 javascript의 arrow function을 좀더 간단하게 사용하는 방법에 대해서 알아보도록 하겠습니다.
arrow function은 =>
의 형태로 함수를 표현하는 것을 의미 합니다.
함수 선언
함수 작성방법 1 : 일반적인 function 사용
let arrowFunctionTest = function(arg1) {
console.log(arg1);
return arg1;
}
arrowFunctionTest('test');
함수 작성방법 2 : =>를 사용
let arrowFunctionTest = (arg1) => {
console.log(arg1);
return arg1;
}
arrowFunctionTest('test');
2에서는 function대신에 =>를 사용하여 함수 표기를 하였습니다.
처음 보면 굉장히 어색할 수도 있지만 계속 보다보면 1번보다 2번이 더 익숙해 질 것입니다.
callback 인자로 넘기기
자 그럼 이번에는 함수 선언이 아닌 arrow function을 callback인자로 넘겨보도록 하겠습니다.
콜백 인자 1 : 일반적인 function 사용
let list = [1, 2, 3, 4, 5];
let newList = list.map(function(item){
return item + 1;
});
콜백 인자 2 : =>를 사용
let list = [1, 2, 3, 4, 5];
let newList = list.map((item) => {
return item + 1;
});
javascript코드를 작성을 하다보면 리스트에서 값을 조작하여 새로운 리스트를 만드는 경우가 상당히 많습니다.
저는 이런 경우 코드를 아무리 잘 짜도 왠지 깔끔하지 않는것 같은 느낌이 들었습니다.
하지만 arrow function을 이용하면 좀더 깔끔한 코드 작성이 가능합니다.
arrow function 간소화 1단계
arrow function은 인자가 하나있을 경우 ()
가 생략이 가능 합니다.
()생략
let list = [1, 2, 3, 4, 5];
let newList = list.map(item => {
return item + 1;
});
우선 ()가 없어지니 한결 깔끔해 보입니다.
하지만 여기서 좀더 간결하게 자꾸어 줄 수 있습니다.
arrow function 간소화 2단계
위 처럼 콜백 함수 내부의 코드가 한줄이라면 {}와 return이 생략 가능 합니다.
{}, return생략
let list = [1, 2, 3, 4, 5];
let newList = list.map(item => item + 1;);
마치 map이라는 array메소드가 간단한 하나의 함수 같이 보입니다.
실행결과
console.log(newList);
---결과---
[2, 3, 4, 5, 6]
각각의 요소가 +1된 값이 저장이 되었습니다.
간소화 한 arrow function을 응용해 보자
let users = ['짱구,맹구', '훈이,유리', '철수,영희'];
시나리오 : users라는 리스트는 각각의 요소에 n명의 유저가 ,
단위로 묶여있다. 각각의 묶여있는 단위를 리스트로 만들기
결과 : [['짱구', '맹구'], ['훈이', '유리'], ['철수', '영희']]
매우 쉬운 상황이다. 여러 방법이 있을 수 있지만 작성을 해보도록 하겠습니다. arrow function과 array.protype.map을 이용해서 작성을 하도록 하겠습니다.
let users = users.map(item => item.split(','));
split을 이용하면 간단하게 작성을 할 수 있습니다.
위 시나리오는 문자열 처리를 할 때 Tokenize를 하기 위해 많이 사용되는 방법입니다.
word2vec같은 라이브러리를 사용해 보셨다면 위와같이 데이터를 만드는 것을 많이 봤을겁니다
마지막으로
=>
와 function
이 100% 작동 방식이 동일 하진 않습니다.
'언어 > 자바스크립트 & 타입스크립트' 카테고리의 다른 글
[react] react 작업환경 설정 (0) | 2017.05.20 |
---|---|
js와 css로 프린트를 제어해보자. (1) | 2017.04.29 |
Javascript Asynchronous, synchronous and Promise (0) | 2017.04.28 |