자바스크립트, 백틱의 신기한 활용
업데이트:
백틱
윈도우 키보드 물결 표시에 있는 이 것. ` 백틱이다.
백틱에는 템플릿 리터럴 이외에, 함수를 호출하는 기능도 있다. (ㄷㄷ!)
Template Literal
1
2
3
4
5
const name = "wichan";
const str = `hello ${name}!`;
// result: hello wichan!
console.log(str);
Template Literal 이라고 부른다.
Tagged Template
각설하고, 이 Tagged Template 때문에 포스팅했다.
1
2
3
4
5
6
7
8
function fun(arg) {
console.log(arg);
}
// result: funny javascript
fun("funny javascript");
// result: [ 'funny javascript' ]
fun`funny javascript`;
함수를 백틱으로 호출하는데 성공했다. 근데 왜 arg가 배열로 들어왔을까?
이럴 때 쓴다.
사실, 백틱으로 함수를 호출할 때 넘어오는 인자가 더 있다.
다음 예제를 보자.
1
2
3
4
5
6
7
8
9
10
11
12
13
const name = "wichan";
const age = 25;
function intro(strings, ...values) {
console.log(strings);
console.log(values);
}
/** result:
* strings: ['my name is ', ' and i am ', ' years old.']
* values: ['wichan', 25]
*/
intro`my name is ${name} and i am ${age} years old.`;
백틱으로 함수를 호출하는 경우 첫번째 인자로 template를 제한 스트링 배열, 그 이후로 템플릿 값들을 인자로 제공한다.
함수에 문자열을 입력할 때, 템플릿 변수와 문자열을 분리할 때 사용할 수 있다.
숨은 기능이 하나 더 있다.
사실 태그드 템플릿에는 숨겨진 기능이 하나 더 있다.
1
2
3
4
5
6
7
8
9
10
function fun(strings) {
console.log(strings);
console.log(strings.raw);
}
/** result:
* [ 'directory: C:System32etc...' ]
* [ 'directory: C:\\System32\\etc...' ]
*/
fun`directory: C:\System32\etc...`;
escaping 되지 않은 원본 문자열을 보여준다.
끝
댓글남기기