Javascript/[기초] Javascript

ES6 기능 정리(ECMAScript 6)

마샤와 곰 2021. 1. 9. 09:30

ECMA라는 것은 표준화된 JavaScript를 만들기 위해 만들어진 사양을 의미 합니다.

그에 따른 버전인 ES6 버전에 대해서 간단하게 내용을 요약하여 보았습니다.

 

1. 변수 선언 방법의 변화(let, const)

 - let 은 블록 범위이며 값이 지정되어도 값을 바꿀 수 있습니다.

 - const도 블록 범위로 사용 되지만 값은 바꿀 수 없는 상수 입니다.

var a = 1
if(1 == 1){
    var a = 234  //함수 내부에 선언되지 않았으므로 글로별 변수와 대체
    console.log(a)  //234
} 
console.log(a)  //234

//////////////////////////////////////////////////
let b = 1
if(1 == 1){
    let b = 234  //if 조건문에서의 블록화
    console.log(b)  //234
} 
console.log(b)  //1

//////////////////////////////////////////////////
const c = 3
if(1 == 1){
    const c = 234  //error!
    console.log(c)
} 

 

2. 템플릿 리터럴(Template Literal)

 - 기존에 문자열을 합치는 경우에 더하기(+) 연산자를 통해 하였습니다.

 - 백틱(숫자 1 옆에있는 기호)을 활용하여 간결하게 표현 할 수 있습니다.

 - 표현하고자 하는 데이터는 달러$ 기호와 중괄호{} 를 통해서 표기하며, 간단한 연산도 가능 합니다.

//기존 문자열 출력 방식
let data = 1234
let desc = 'data is '
console.log(desc + data)

//변경
let data = 1234
let desc = `data is ${data}, ${data * 3}`
console.log(desc)

 

3. 반복문 (for in, for of)

let array = ['a', 'b', 'c']
for(let i in array){
    console.log(i)   //0, 1, 2 (인덱스 값이 출력 됩니다.)
}

for(let i of array){
    console.log(i)  //a, b, c
}

 

4. 기본 매개변수(Default Parameters)

 - 함수에서 기본 값을 지정하여 줄 수 있습니다.

function fun(a = 5, b = 5, c = 10) {
    return a + b + c
}
console.log(fun()) // 20이 출력 됩니다.

 

5. 화살표 함수(Arrow Function)

 - 화살표 함수는 기존의 함수를 간결하게 표현 해 주는 기능 입니다.

 - 일반함수와 화살표함수와의 가장 큰 차이는 일반함수는 자신만의 데이터를 가질 수 있는 반면, 

   화살표 함수는 그렇지 못하다는 점 입니다.

function fun(arg){
    console.log(arg)
    return arg
}
fun(1) //1이 출력됩니다.

let fun2 = (arg)=>{
    console.log(arg)
    return arg
}
fun2(1)   //1이 출력됩니다. 

//////////////////////////////////////////////////

function fun(arg){
    this.name = arg
}
new fun(1234).name  //1234가 출력됩니다.

let fun2 = (arg)=>{  //new 연산자를 통한 생성은 불가능
    this.name = arg
}
new fun2(1234).name  //에러발생!

 

6. 객체 정의 방법(Define Object)

 - 객체를 정의하는 방법이 편리 해 졌습니다.

 - 무조건 key : value로 정의하던 부분을 생략을 해서 사용 할 수 있습니다.

let fun = {
    name : 'picachoo',
    print(){  // 콜른(:)없이 표기 가능
        console.log(this.name)
    }
}
fun.print()  //picachoo

let width = 100
let height = 200
let position = { width, height }  //콜른(:)없이 표기 가능
console.log(position)  // { width : 100, height : 200 }

 

7. 객체의 복사(Copy Object)

 - Object 객체에 assing이라는 함수가 추가 되었습니다.

 - 배열, 객체 등 참조하는 값을 복사 할 때 얕은 복사를 할 수 있습니다.  * 수정 : 2022-05-20

let array = [1,2,3,4]
let new_array = Object.assign([], array)  //기본값에 복사할 값을 넣습니다.
                                          //기본값에 0,0,0,5,6이 있으면 위 array의 1,2,3,4가 0,0,0,0을 대체하고
                                          //나머지 5,6이 뒤에 추가 됩니다.                                          
array[0] = 123
console.log(array)  //123, 2, 3, 4
console.log(new_array) //1, 2, 3, 4  -> array의 변경에 대해 영향받지 않음.

 

8. 계산된 속성 이름(Computed Property Name)

 - key와 value값을 가진 객체는 key값을 이제 동적으로 부여 할 수 있습니다.

 - 한번 동적으로 부여된 key 값은 변경 할수는 없습니다.

let KEY = 'name'
let data = {
    [KEY] : 'value',  //동적으로 적용 가능
    [`change_${KEY}`] : 'value2'
}
console.log(data)  // { name : value, change_name : value2 }

KEY = 'change?'  
console.log(data) //이미 할당이 끝난 값은 변경 불가능  { name : value, change_name : value2 }

 

9. 구조분해 할당(Destructing Assignment)

 - 데이터를 할당하려면 대입 연산자를 통해서 할 수 있었습니다. 예)  var a = 1; var b = a;

 - 데이터를 할당 하는 기능을 간결하게 할 수 있게 되었습니다.

 - 배열 값은 대괄호[]를 사용해서 간단하게 할당 할 수 있으며, 객체값은 중괄호{}를 사용해 할당 할 수 있습니다.

//일반적인 사용 방법
let arr = ['1', '2', '3']
let [one, two, three] = arr
console.log(one) // 1
console.log(two) // 2
console.log(three) // 3

let [, , wow] = arr  //첫번째, 두번째를 빈값으로 선언
console.log(wow)  //3 


//////////////////////////////////////////////////
//값 할당(서로 바꾸기)
let num = 123;  
let text = 'hi'; 
[num, text] = [text, num]
console.log(num, text)


//////////////////////////////////////////////////
//객체의 값에 대해 적용
let data = {width : 100, height : 200}
let {width, height} = data
console.log(width)  //100
console.log(height)  //200

//////////////////////////////////////////////////
//다양한 변환
let param = {
    jsn : {
        name : 'hello',
        number : 1543
    },
    arr : [
        {arr_name : 'world', index : 4567},
        {arr_name : 'world record', index : 5513},
    ],
    param_text : 'im param_text'
}

let {jsn : {name : re_name}, arr : [{arr_name : new_name}], param_text} = param

//re_name은 param.jsn.name을 변환하여 별칭을 준 값
//new_name은 param.arr배열의 첫번째 arr_name을 변환하여 별칭을 준 값
//param_text는 param.param_text의 값을 변수명 그대로 사용한 값(별칭부여X)
console.log(re_name, new_name , param_text)

 

10. 전개구문 연산자(Spread operator)

 - 자바에서의 가변인자와 비슷한 기능 입니다.  * 앗차..자바를 안써보신분도 있겠구나..

 - 받으려는 데이터를 n개(가변)로 하여 받을 수 있습니다.

//일반 사용법
function numbers(...arg){
    console.log(arg)
}
numbers(1,2,3,4,5)  // 1,2,3,4,5  -> 배열 타입 입니다.


//////////////////////////////////////////////////
//대입하기
let number = [1, 2, 3, 4, 5]
let [one, two, ...nums] = number

console.log(one) // 1
console.log(two) // 2
console.log(nums) // [3, 4, 5]


//////////////////////////////////////////////////
//객체 복사
let obj1 = { string: 'bar', int: 42 }
let obj2 = { ...obj1 }
console.log(obj1, obj2)  


//////////////////////////////////////////////////
//배열 복사
let arr = [1,2,3,4,5]
let arr2 = [...arr]
arr[0] = 100
console.log(arr)  // 100,2,3,4,5
console.log(arr2) // 1,2,3,4,5

 

11. 클래스(Class)

 - 클래스라는 기능은 1개의 영역 안에 다양한 함수, 변수 등을 집어넣고 사용 할 수 있게 해주는 기능 입니다.

 - 클래스는 new 연산자를 통해서 생성 할 수 있으며, 호이스팅이 되지 않으므로 유의하여야 합니다.

 - 클래스에서 함수는 function을 제거하고 선언 합니다.

 - 클래스에서 static 함수는 new로 생성된 변수에서 접근하는 것이 아니라 클래스에서 바로 접근해야 합니다.

 - 클래스는 다른 클래스를 상속 받아서 기존 클래스의 기능을 이어받을 수 있습니다.

//클래스 사용 방법
class Building {
    constructor(width, height) {
        this.width = width
        this.height = height
    }
    log(){  //function을 생략하고 함수를 사용
        console.log(this.width, this.height) 
    }
    static print(num){  //static 함수
        console.log(num) 
    }
}

let apt = new Building(100, 200)
console.log(apt.width, apt.height) //100, 200
Building.print(200)  //200  -> 오류 발생 : apt.print(200)


//////////////////////////////////////////////////
//상속받아 사용하는 방법
class Apart extends Building {  //상위클래스의 생성자를 구현해야 함.
    constructor(width, height) {  
        this.width = width
        this.height = height
    }
    //log, print 함수를 지니고 있음.
}

let apt2 = new Apart(100, 200)
console.log(apt2.width, apt2.height) //100, 200
Apart.print(200) 

 

12. 모듈(Modules)

 - export, import 를 통해 나누어서 개발된 파일(*.js)간의 관계를 유지하여 줍니다.

 - js파일에서 전달할 기능은 export, 사용하는 곳에서는 import를 선언하여 서로의 위치를 참조하게 합니다.

 - 기존에 html파일에서 <script />테그로 사용하는 경우 속성값인 type을 module로 해야 합니다.

* test.js
export const test_number = 1234

* test2.js
import * as testCode from "./test.js"

console.log(testCode.test_number)  //1234

 

13. 약속(Promise)

 - 비동기 프로세스의 순서를 보장할 때 사용합니다.

 - Ajax나 특정 파일 입출력 행위에 대해서 순서가 보장 될 때 주로 사용 합니다.

let prom = (num) => {
    return new Promise((res, fail) => {
        if (num > 4) {
            res(num)  //성공이면,
        } else {
            fail("err")  //에러발생
        }
    })
}

prom(5)
    .then(val => console.log(val)) // 5 출력
    .catch(err => console.log(err))

 

이상으로 ES6 문법에 대해서 간단하게 정리하여 보았습니다.

그러나 ES6 문법의 거의 대부분은 익스플로러(Explorer)에서 동작하지가 않습니다.. 그렇기 때문에 아직도 많은 수의 웹 개발자 분들이 ES6문법의 해택을 받지 못하고 있습니다.

하루 빨리 대한민국의 생태계가 빨리 바뀌어 익스플로러가 종료 되었으면 하는 바램 입니다.

궁금한 점이나 틀린 내용이 있으면 언제든 연락 주세요! :)

반응형