티스토리 뷰
Intro
ES6의 여러가지 문법 중 Vue.js 코딩을 간편하게 해주는 문법 학습
const & let, Arrow Function, Enhanced Object Literals, Modules 학습
ES6 란?
ECMAScript 2015와 동일한 용어
2015년은 ES5(2009년)이래로 진행한 첫 메이저 업데이트가 승인된 해
최신 Front-End Framework인 React, Angular, Vue에서 권고하는 언어 형식
ES5에 비해 문법이 간결해져서 익숙해지면 코딩을 훨씬 편하게 할 수 있음
Babel
구 버전 브라우저 중에는 ES6의 기능을 지원하지 않는 브라우저가 있으므로 transpiling이 필요
ES6의 문법을 각 브라우저의 호환 가능한 ES5로 변환하는 컴파일러
module: {
loaders: [{
test: /\.js$./,
loader: 'babel-loader',
query: {
presets: ['es2015']
}
}]
},
const & let
새로운 변수 선언 방식
블록단위
{ }
로 변수의 범위가 제한되었음const
: 한번 선언한 값에 대해서 변경할 수 없음(상수 개념)let
: 한번 선언한 값에 대해서 다시 선언할 수 없음
위 특징들에 대해 자세히 알아보기 전에 ES5 특징 2가지를 리뷰한다.
ES5 특징 - 변수의 Scope
기존의 자바스크립트(ES5)는
{ }
에 상관없이 스코프가 설정됨for문 안의 i를 밖에서 참조할 수 있다.(!!!!!!)
var sum = 0;
for (var i = 1; i <= 5; i++) {
sum = sum + 1;
}
console.log(sum); // 15
console.log(i); // 6
ES5 특징 - Hoisting
Hoisting이란 선언한 함수와 변수를 해석기가 가장 상단에 있는 것처럼 인식한다.
js 해석기는 코드의 라인 순서와 관계 없이 함수 선언식과 변수를 위한 메모리 공간을 먼저 확보한다.
함수 선언식
function sum() {
return 10 + 20;
}함수 표현식
var sum = function() {
return 10 + 20;
}
따라서,
function a()
와var
는 코드의 최상단으로 끌어 올려진 것(hoisted)처럼 보인다.function willBeOverriden() {
return 10;
}
willBeOverriden(); // 5
function willBeOverriden() {
return 5;
}아래와 같은 코드를 실행할 때 자바스크립트 해석기가 어떻게 코드 순서를 재조정할까?
호이스팅에 의해서 변수와 함수선언문이 위로 끌어올려지고,
두번째로 연산이 일어난다. sum + i
세번째로 할당이 일어난다. sum = sum + i
신기하겠지만(js로 시작을 하지 않아서...) 재조정 결과를 보자
var sum = 5;
sum = sum + i;
function sumAllNumbers() {
// ...
}
var i = 10;// #1 - 함수 선언식과 변수 선언을 hoisting
var sum;
function sumAllNumbers() {
//...
}
var i;
// #2 - 변수 대입 및 할당
sum = 5;
sum = sum + i;
i = 10;
ES6 -
{ }
단위로 변수의 범위가 제한됨let sum = 0;
for (let i = 1; i <= 5; i++) {
sum = sum + i;
}
console.log(sum); // 10
console.log(i); // Uncaught ReferenceError: i is not definedES6 -
const
로 지정한 값 변경 불가능const a = 10;
a = 20; // Uncaughr TypeError: Assignment to constant variable하지만, 객체나 배열의 내부는 변경할 수 있다.
const a = {};
a.num = 10;
console.log(a); // {num: 10}
const a = [];
a.push(20);
console.log(a); // [20]
ES6 -
let
선언한 값에 대해 다시 선언 불가능let a = 10;
let a = 20; // Uncaught SyntaxError: Identifier 'a' has already been declaredES6 - const, let
function f() {
let x;
{
// 새로운 블록안에 새로운 x의 스코프가 생김
const x = "sneaky";x = "foo";
// 이전 블록 범위로 돌아왔기 때문에 `let x`에 해당하는 메모리에 값을 대입
x = "bar";
let x = "inner"; // Uncaught SyntaxError: Identifier 'x' has already been declared
}
}
Arrow Function
함수를 정의할 때
function
이라는 키워드를 사용하지 않고=>
로 대체흔히 사용하는 콜백 함수의 문법을 간결화
// ES5 함수 정의 방식
var sum = function(a, b) {
return a + b;
};
// ES6 함수 정의 방식
var sum = (a, b) => {
return a + b;
}
sum(10, 20);
화살표 함수 사용 예시
// ES5
var arr = ["a", "b", "c"];
arr.forEach(function(value) {
console.log(value); // a, b, c
});
// ES6
var arr = ["a", "b", "c"];
arr.forEach(value => console.log(value)); // a, b, c
Babel 온라인 에디터로 실습하기 ES6 -> ES5로 변경되는 코드
Enhanced Object Literals
향상된 객체 리터럴
객체의 속성을 메서드로 사용할 때
function
예약어를 생략하고 생성 가능
var dictionary = {
words: 100,
// ES5
lookup: function() {
console.log("find words");
},
// ES6
lookup() {
console.log("find words");
}
};
객체의 속성명과 값 명이 동일할 때 아라와 같이 축약 가능
var figures = 10;
var dictionary = {
// figures: figures,
figures
};
Modules - 자바스크립트 모듈화 방법
자바스크립트 모듈 로더 라이브러리(AMD, Commons JS) 기능을 js 언어 자체에서 지원
호출되기 전까지는 코드 실행과 동작을 하지 않는 특징이 있음
// libs/math.js
export function sum(x, y) {
return x + y;
}
export pi = 3.141592;
// main.js
import {sum} from 'libs/math.js';
sum(1, 2);
Vue.js 에서 마주칠
default
exportdefault 키워드가 붙으면 한개의 파일에서 하나 밖에 export 되지 않는다.
다른 것들이 import 되지 않게 모듈화 한다.
// util.js
export default function(x) {
return console.log(x);
}// main.js
import util from 'util.js'
console.log(util); // function(x) { return console.log(x); }
util("hi");// app.js
import log from 'util.js'
console.log(log);
log(hi);
Object Spread Operator
Spread 구문(
...
)을 사용하면 배열이나 문자열과 같이 반복 가능한 문자를 0개 이상의 인수(함수 호출할 경우) 또는 요소(배열 리터럴의 경우)로 확장하여, 0개 이상의 key-value 쌍의 객체로 확장시킬 수 있다.함수 호출에서의 Spread
일반적으로 배열의 엘리먼트를 함수의 인수로 사용하고자 할 때
Function.prototype.apply
를 사용했다.하지만, Spread 문법을 사용해서 대체할 수 있다.
function sum(x, y, z) {
return x + y + z;
}
const numbers = [1, 2, 3];
console.log(sum(numbers));
// expected output: 6
console.log(sum.apply(null, numbers));
// expected output: 6인수 목록의 모든 인수는 Spread 문법을 사용할 수 있으며, 여러번 사용될 수도 있다.
function myFunction(v, w, x, y, z) { }
var args = [0, 1];
myFunction(0, args, args); // 2
객체 리터럴에서의 Spread
Object 리터럴에 Spread를 추가하면, 객체가 소유한 열거형 프로퍼티를 새로운 객체로 복사한다.
var obj1 = { foo: 'bar', x: 42 };
var obj2 = { foo: 'baz', y: 13 };
var clonedObj = { obj1 };
// Object { foo: "bar", x: 42 }
var mergedObj = { obj1, obj2 };
// Object { foo: "baz", x: 42, y: 13 }ES5에서 객체의 특정 값들을 다른 객체로 복사할 때
let myObj = {
prop1: 'Hello',
prop2: 'World'
};
let newObj = {
name: 'George',
prop1: myObj.prop1,
prop2: myObj.prop2
};
console.log(newObj.prop1); // HelloES6의 Spread 연산자를 적용한 후
let newObj = {
name: 'George',
myObj
};
console.log(newObj.prop1); // Hello
뷰엑스에서 Object Spread Operator 적용예시
기존 자바스크립트 방식에서 state 속성 선언하는 부분
// store.js
new Vuex.Store({
state: {
prop1: ,
prop2: ,
prop3:
}
});// app.js
new Vue({
computed: {
prop1() {
return store.state.prop1;
},
prop2() {
return store.state.prop2;
}
}
});뷰엑스에서 제공하는 mapState함수를 이용하면 위 코드처럼
state
에 일일이 접근하지 않아도 된다.import { mapState } from 'vuex';
var state = mapState(['prop1', 'prop2', 'prop3']);mapState에
...
연산자를 붙여 computed 속성에서 쉽게 뷰엑스의state
에 접근할 수 있다.// app.js
import { mapState } from 'vuex';
new Vue({
computed: {
someLocalComputedProp() { },
mapState(['prop1', 'prop2', 'prop3'])
}
});
Reference
'ICT Eng > Vue.js' 카테고리의 다른 글
[Vue.js] Vuex의 주요 기술 요소 (1) | 2019.03.01 |
---|---|
[Vue.js] Vuex란? Vuex의 컨셉과 구조 (0) | 2019.03.01 |
[Vue.js] 08. Vue Templates(뷰 템플릿) (0) | 2018.10.08 |
[Vue.js] 07. Vue Resource (0) | 2018.10.08 |
[Vue.js] 06. Vue Router(뷰 라우터) (0) | 2018.09.28 |
- Total
- Today
- Yesterday
- 순환
- 인프런
- Recursion
- 젠킨스
- 한밭이글스
- 무선통신소프트웨어연구실
- ORM
- Spring Boot
- Vue.js
- Spring
- vuex
- springboot
- JPA
- Raspberry Pi
- 라즈베리파이
- github
- 레드블랙트리
- vuejs
- Wisoft
- Java
- 자바
- 스프링부트
- 한밭대학교
- 알고리즘
- 시간복잡도
- IT융합인력양성사업단
- AWS
- 정렬
- RBT
- Algorithm
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |