Study/Vue.js
[Vue.js] 09 ES6
록씨
2021. 9. 24. 09:53
반응형
개요
- ECMAScript 2015
- Vue.js 코딩을 간편하게 해주는 문법 학습
- const & let
- Arrow Function
- Enhanced Object Literals
- modules
- Spread Operator
- Babel, Can I use
const & let
- ES6에서 사용하는 변수 선언 방식
let
- 한번 선언하면 다시 선언할 수 없다.
// 똑같은 변수를 재선언할 때 오류
let a = 10;
let a = 20; // Uncaught SyntaxError: Identifier 'a' has already been declared
const
- 한번 할당한 값을 변경할 수 없다.
// 값을 다시 할당했을 때 오류
const a = 10;
a = 20; // Uncaught TypeError: Assignment to constant variable.
- 단, 객체 {}또는 배열 []로 선언했을 때는 객체의 속성(property)과 배열의 요소(element)를 변경할 수 있다.
// 객체로 선언하고 속성 값을 변경
const b = {
num: 10,
text: 'hi'
};
console.log(b.num); // 10
b.num = 20;
console.log(b.num); // 20
// 배열로 선언하고 배열 요소를 추가
const c = [];
console.log(c); // []
c.push(10);
console.log(c); // [10]
블록 유효범위
- ES5의 var를 이용한 변수 선언 방식과 let & const를 이용한 변수 선언 방식의 가장 큰 차이점은 블록 유효범위이다.
var의 유효 범위
- var의 유효 범위는 함수의 블록 단위로 제한되며 흔히 함수 스코프(function scope)라고 표현
var a = 100; // window
function print() {
var a = 10; // print()
console.log(a);
}
print(); // 10
for 반복문에서의 var 유효 범위
- var의 유효 범위가 {}에 제한되나?
var a = 10;
for (var a = 0; a < 5; a++) {
console.log(a); // 0 1 2 3 4 5
}
console.log(a); // 6
const와 let의 블록 유효범위
- 반복문의 조건 변수 a를 let으로 선언하니 변수의 유효 범위가 for 반복문의 {} 블록 안으로 제한됨.
var a = 10;
for (let a = 0; a < 5; a++) {
console.log(a); // 0 1 2 3 4 5
}
console.log(a); // 10
화살표 함수(Arrow Function)
- ES6의 새로운 함수 정의 방식입니다.
기존의 함수 정의 방식
기존 자바스크립트의 함수 정의 방식
var a = function() {
// ...
};
화살표 함수 정의 방식
화살표 함수를 이용한 함수 정의 방식
var a = () => {
// ...
};
화살표 함수의 다양한 문법
화살표 함수를 정의하는 방식은 간단한 자바스크립트 표현식부터 {} 를 이용한 선언 방식까지 여러 방법이 있다.
1. 단순한 자바스크립트 표현식
단순한 자바스크립트 표현식의 경우 아래와 같이 간소화 문법을 사용할 수 있다.
() => 10 + 20; // {} 필요 없음
2. 함수 선언 방식
복잡한 자바스크립트 선언문이 들어갈 경우에는 {}를 사용하여 아래와 같이 구현.
() => {
print();
log();
return 10 + 20;
};
3. 전달 인자(parameter)가 하나인 경우
인자를 1개만 선언하는 경우 인자를 받을 때 사용하는 소괄호() 를 생략할 수 있다.
const a = (num) => { return num * 10 };
const b = num => num * 10;
a(10); // 100
b(10); // 100
화살표 함수 this
- 일반함수가 전역 컨텍스트에서 실행될 때 this가 정의
- 화살표함수는 this를 정의하지 않는다.
- 함수의 내부함수, 콜백함수에 사용되는 this는 window이다.
let cat = {
sound: "meow",
soundPlay: function () {
console.log(this) // 가.
setTimeout(function () {
console.log(this) // 나.
console.log(this.sound); // 다.
}, 1000);
}
}
cat.soundPlay();
// 가. cat {sound: "meow", soundPlay: ƒ}
// 나. window
// 다. undefined -----> undefined인 이유는 window에 sound가 없어서
일반함수
// 함수안에 that 변수를 선언하기
let cat = {
sound: "meow",
let that = this // that 사용
soundPlay: function () {
setTimeout(function () {
console.log(that.sound);
}, 1000);
}
}
// bind 사용하기
let cat = {
sound: "meow",
soundPlay: function () {
setTimeout(function () {
console.log(this.sound);
}.bind(this), 1000);
}
}
화살표 함수
let cat = {
sound: "meow",
soundPlay: function () {
setTimeout(() => {
console.log(this.sound);
}, 1000);
}
}
향상된 객체 리터럴(Enhanced Object Literal)
- 자바스크립트에서 사용하던 객체 정의 방식을 개선한 문법
기존 객체 정의 방식
var josh = {
// 속성: 값
language: 'javascript',
coding: function() {
console.log('Hello World');
}
};
축약 문법 1 - 속성과 값이 같으면 1개만 기입
- 객체를 정의할 때 속성(property)와 값(value)이 같으면 아래와 같이 축약이 가능
var language = 'javascript';
var josh = {
// language: language,
language
};
console.log(josh); // {language: "javascript"}
// #1 - 컴포넌트 등록 방식에서의 축약 문법
const myComponent = {
template: '<p>My Component</p>'
};
new Vue({
components: {
// myComponent: myComponent
myComponent
}
});
// #2 - 라우터 등록 방식에서의 축약 문법
const router = new VueRouter({
// ...
});
new Vue({
// router: router,
router
});
축약 문법 2 - 속성에 함수를 정의할 때 function 예약어 생략
const josh = {
// 속성: 함수
coding: function() {
console.log('Hello World');
}
};
josh.coding(); // Hello World
- ES6에서는 아래와 같이 축약하여 코딩하는 것을 추천함.
const josh = {
coding() {
console.log('Hello World');
}
};
josh.coding(); // Hello World
ex)
new Vue({
// ...
methods: {
fetchData: function() {
// ...
},
showAlert: function() {
// ...
}
}
});
new Vue({
// ...
methods: {
fetchData() {
// ...
},
showAlert() {
// ...
}
}
});
modules
- 임포트(Import)와 익스포트(Export)는 자바스크립트의 코드를 모듈화 할 수 있는 기능
- 모듈화란 쉽게 말해서 다른 파일에 있는 자바스크립트의 기능을 특정 파일에서 사용할 수 있는 것.
모듈화의 필요성
- 기본적으로 자바스크립트의 유효 범위는 전역으로 시작하는데 아래와 같이 HTML 페이지를 로딩하면 원하는 결과가 나오지 않는다.
<!-- index.html -->
<body>
<script src="a.js"></script>
<script src="b.js"></script>
<script>
getTotal(); // 200
</script>
</body>
// a.js
var total = 100;
function getTotal() {
return total;
}
// b.js
var total = 200;
import & export 기본 문법
export 변수, 함수
import { 불러올 변수 또는 함수 이름 } from '파일 경로';
import & export 기본 예제
- 변수
// math.js
export var pi = 3.14;
import { 불러올 변수 또는 함수 이름 } from '파일 경로';
- 함수
// math.js
export var pi = 3.14;
export function sum(a, b) {
return a + b;
}
// app.js
import { sum } from './math.js';
sum(10, 20); // 30
스프레드 오퍼레이터(Spread Operator)
- 펼침 연산자
- 스프레드 오퍼레이터는 특정 객체 또는 배열의 값을 다른 객체, 배열로 복제하거나 옮길 때 사용
- 연산자의 모양은 ...
기존 자바스크립트의 객체 복제 방식
기존 자바스크립트 문법으로만 구현하면..
// 객체의 값을 복사하는 경우
var obj = {
a: 10,
b: 20
};
var newObj = {
a: obj.a,
b: obj.b
};
console.log(newObj); // {a: 10, b: 20}
// 배열의 값을 복사하는 경우
var arr = [1,2,3];
var newArr = [arr[0], arr[1], arr[2]];
console.log(newArr); // [1, 2, 3]
스프레드 오퍼레이터 사용법
// obj 객체를 newObj 객체에 복제
var obj = {
a: 10,
b: 20
};
var newObj = {...obj};
console.log(newOjb); // {a: 10, b: 20}
// arr 배열을 newArr 배열에 복제
var arr = [1,2,3];
var newArr = [...arr];
console.log(newArr); // [1, 2, 3]
// 다수 파라미터
function addNums(...nums) {
return nums.reduce((a, b) => a+b, 0);
}
addNums(...arr);
반응형