변수, 함수, 클래스 내보내기

// 배열 내보내기
export let foods = ["pizza", "hamburger", "chicken"];

// 상수 내보내기
export const MODULES_BECAME_STANDARD_YEAR = 2015;

// 클래스 내보내기
export class User {
	construcor(name) {
    	this.name = name;
    }
}

// 함수 내보내기
const App = () => console.log("hello");
export default App;

// 모듈 내보내기
export { name1, name2 as yeji, ..., nameN} 	// does not set the default export

 

함수 가져오기

import {sayHi, sayBye} from "./say.js";



// say.js
const sayHi = () => console.log("hello");
const sayBye = () => console.log("bye");

const etcHi = () => console.log("bye");
const etcBye = () => console.log("bye");


export default {sayHi, sayBye};

원하는 함수만 import 선언해주면 빌드툴은 선언되지않은 함수는 최종 번들링 결과물에 포함하지 않습니다.

이 과정에서 불필요한 코드가 제거되기 때문에 빌드 결과물의 크기가 작아집니다. -> tree-shaking

 

모듈 export default

 

모듈은 크게 두종류로 나뉩니다.

 

1. 복수의 함수가 있는 라이브러리 형태의 모듈

2. 개체 하나만 선언되어있는 모듈

 

대체로 두번째 방식으로 모듈을 만드는걸 선호 합니다.

 

// user.js
export default class User {
	constructor(name) {
    	this.name = name;
    }
}

// main.js
import User from "./user.js"; // default 한 모듈을 가져오려면 중괄호가 필요 x

new User("john");

export default를 사용하면 해당 모듈엔 개체가 하나만 있다는 사실을 명확히 나타낼 수 있습니다.

최대 하나의 default export가 있으므로 내보낼 개체에 이름이 없어도  해당 모듈을 사용할 수 있습니다.

 

사용예)

export default class {	//클래스 이름이 없음
	constructor() {...}
}

export default () => console.log("say hello"); // 함수 이름이없음

export default ["jan", "yeji", "yunrap"]  // 이름없이 배열형태의 값내보냄

 

자바스크립트에서 가장 중요한 개념은 함수다.

자바스크립트에서 이러한 함수를 얼마나 제대로 이해하고 활용하는가 따라서 고급 자바스크립트 개발자로 거듭날수있다.

함수표현법에서 ECMAScript 6 버젼인 arrow function 의 사용법이있다.

 

우선  ECMAScript가 뭘까? Ecma 기관이만든 script 언어이다. 

자바스크립트를 개발한 Netscape 가 더 향상된 표준화를 위해 기술 규격을 ECMA에 제출 했고 그에 따라 새롭게 제정한 표준이
ECMA-262이다. 즉  ES6 표준을 따른다는 말은 ECMAScript 2015가 사용중인 ECMA 규격을 따라서 문법을 사용한다라고 알면된다.

년도를 붙여서 사용하므로 ECMAScript 2015(=ES6)는 2015년 에배포된 버젼,

최근에나온 버전은 ES2020(=ES11) 버전까지있다. ES11 버전이나왔지만 ES6는 기존의 문제의 해결, 가독성 및 유지보수성이 보강된 문법이 대거 추가되서 아직 많이사용중이다.

 

여기까지 알고 ES6의 화살표함수에대해 알아보자

 

 

1. 화살표 함수 (arrow function)

 

블로그 copy 포스팅

 

- 함수 표현방법 1

// 기존의 함수표현식방식
const func1 = function()  {
	const num = 10;`
};

// 익명함수 = 화살표함수 = 함수를 변수에 할당
// function 키워드 생략
const func2 = () => { 
	const num = 10; 
}; // function 키워드 생략 가능

// 함수의 매개변수에 괄호 생략가능
const func2 = num => {
	const sum = num;
}

// 표현식이 하나라면 중괄호와 return 문 생략가능
const func3 = num => `입력된 숫자는 ${num}입니다.`;

 

 

 

mdn 사이트 포스팅

 

- arrow funtcion 특징

1. this나 super에 대한 바인딩이 없고, methods로 사용될수 없습니다.

2. new.target키워드가 없다

3. 일반적으로 스코프를 지정할 때 사용하는 call, apply, bind methods를 이용할 수 없다.

4. 생성자로 사용할 수 없다.

5. yield를 활살표 함수 내부에서 사용할 수 없다.

 

 

- 함수 표현방법 2

// 객체 리터럴 표현을 반환하기위해서는 함수 본문을 괄호 속에 넣음
params => ({ yeji : 28 })

// 나머지 매개변수 및 기본 매개변수를 지원함
(param1, param2, ...rest) => { statements }
(param1 = defaultValue1, param2, paramN = defaultValueN) => { statements }

// 매개변수 목록 내 Destructuring assignment 지원
var f = ([a, b] = [1, 2],  {x, c} = {x, a + b}) => a + b + c;
f();	// 6

 

 

 

arrow function 을 알아봤다면 this의 개념에대서 알아보자

 

 

 

2. 함수 호출과 this 

블로그 copy 포스팅

 

자바에서는 this 키워드를 익숙하게 써왔다

하지만 자바스크립트에서의 this는 자바처럼 단순하지 않다.

 

1. 함수실행

2. 메소드(함수 내부) 실행

3. 생성자 실행

4. 간접 실행

 

 

 

- 함수실행에서 this

함수 실행에서 this는 전역객체를 가르킨다.

 

하지만, es6에서 arrow function안에서 존재하는 this는 정적(lexically)로 결합시키기 때문에 전역객체인(window)가아닌 

맥락상 위의 코드부터 보고 결합을 시키게된다.

 

const o = {
    name: "yeji",
    speak: function() {
        getName = () => {
            return `${this.name}`;
        }
     return `My name is ${getName};
    }
};

o.speack() // My name is yeji

 

- 메소드 실행

바로 arrow function을 객체안에쓴다면 this를 불러올수없다.

const obj = {
    a: "hi",
    b: () => console.log(this.a);	// undifined
    c: function () {
        console.log(this.a);	// "hi"
    }
}

 

보통 많이사용하는 법 (

const obj = {
    a:"hi",
    b:function() {
    	 console.log(this.a);	// "hi"
    },
    c:function() {
        console.log(this.a);	// "hi"
    }
}

obj.b();
obj.c();

만약에  arrow function을 사용하고싶다면?

const obj = {
	a: "hi",
    b: function () {
    	return(() => console.log(this.a));
    },
    c: function () {
    	console.log(this.a)
    }
}

obj.b();
obj.c();

 

 

이렇게 IIFE 형식으로 사용하면된다. (IIFE 형식은 다음에 포스팅)

 

 

 

 

 

- 생성자 실행

.....포스팅중

오늘의 일지부분

 

1. 테이블에서 as로 별칭을 통해서 가져오지않아서 데이터를 읽어올수없었던점이다.

 

2. ==와 equal의 차이

 

3. jpql을사용해서 데이터비교하는것과 다시가져오는거 해보기

 

4. jpql과  sql문을 사용했지만 어노테이션부분이 새로웠다. (다시확인해보기)

 

5. 내가 수정했던게 과연잘한방법일까....

'프로그래밍 > 개발 용어와 개념' 카테고리의 다른 글

[개발노트] 리액트 라우팅  (0) 2022.06.16

https://kwiki.devserum.com/ko/articles/tech-articles/2021-05-31-518-consecutive-days-algorithm-challenge

 

518일동안 단 하루도 빠지지 않고 알고리즘을 풀었다.

 

kwiki.devserum.com

 

코드워즈를 사용해보려고한다.

그이유라면 이블로그에올린게 멋있었기때문이다. ㅋㅋ

 

꾸준히 할진 모르겠지만

풀고 이블로그에 계속올려보려고한다.

 

문제를 보고 틈틈히 그문제를 생각해보고 저녁에는 커밋하는방식?

 

알고리즘을 공부하는이유라면 조금더 코딩에 친숙해지고 복붙보다 직접 코딩을해보고 싶은 마음에 배우기로했다.

 

 

+ Recent posts