• 회원가입
  • 로그인
  • 구글아이디로 로그인

[Basic] JS - const (컨스트 = 콘스트) ★★★★★ - 재할당 불가한 변수선언

ECMAScript 2015 (= ES2015 = ES6) 때 도입

 

1.
변수 선언 키워드 2개 새로 도입
const , let

2.
const : 데이터 재할당 X (그외는 let과 유사) 
let     : 데이터 재할당 O.



[const 사용 장점]

 

・Security (보안) : 해커가 값 변경하는 걸 방지.

・Thread Safety : 프로세스 안의 여러 thread가 변수 접근할 때 안전.

・Reduce Human Mistakes : 개발자 실수를 줄여줌.

 


[참고]

JavaScript = ECMAScript + BOM(Browser Object Model) + DOM(Document Object Model)

※ 즉, JS = (1코어 + 2모델)로 구성된 웹언어

 

ECMAScript (이하 ES) 

JS 구성 코어(Core)스크립트 언어로써, 다양한 환경에서 운용될 수 있게 확장성이 뛰어난 웹언어.


더 자세한 정보는 여기 참고

 

const 예제

 

<p id="demo"></p>


<script>

try {

  const hz = '홈짱닷컴';

  hz = 'Homzzang.com';  // const로 앞서 정의된 변수라 에러 발생

  hz = hz + 'Homzzang.com';  // const로 앞서 정의된 변수라 에러 발생

}

catch (err) {

  document.getElementById("demo").innerHTML = err;

}

</script>

 

결과보기
TypeError: Assignment to constant variable.

 

 

const 특징1 :  블럭 경계 안에서만 유효

 

<p id="hz"></p>


<script>

var  x = "홈짱닷컴";

{  

  const x = "Homzzang.com";

}

document.getElementById("hz").innerHTML = x;

</script>

 

결과보기

홈짱닷컴

 

 

const 특징2 - 선언과 동시에 값이 할당돼야 함.

 

const hz = '홈짱닷컴';

 


 

[바람직 X]

const hz;

hz = '홈짱닷컴';

 

 

 

const 특징3 - 진짜 상수를 정의하는 건 아님.

 

1.
const 키워드는 상수 (a constant value)를 정의하는 것이 아니라,
값에 대한 항구적인 참조 자체 (a constant reference to a value)를 정의하는 것임.

2.
이런 성격때문에,
항구적인 기초값 (constant primitive values)을 변경할 순 없지만, 
항구적인 객체의 속성 (the properties of constant objects) 변경은 가능.

 

 

const 특징4 - 기초값 변경 불가

 

<p id="demo"></p>


<script>

try {

  const hz = '홈짱닷컴';

  hz = 'Homzzang.com';  // const로 앞서 정의된 변수라 에러 발생

  hz = hz + 'Homzzang.com';  // const로 앞서 정의된 변수라 에러 발생

}

catch (err) {

  document.getElementById("demo").innerHTML = err;

}

</script>

 

결과보기
TypeError: Assignment to constant variable.

 


 

PS.

 

엘리 님 (JS 3. var, let, const 차이) 강의

https://youtu.be/OCCpGh4ujb8

 



분류 제목
DOM_Document JS - implementation 속성 - DOMimplementation (돔구현객체)를 Document…
DOM_Document JS - importNode() 메서드 ★ - 다른문서의 노드복사해서 가져오기 (IE9 이상) ※ 아이프레임…
DOM_Document JS - inputEncoding 속성 - 입력인코딩문자셋 (= 입력인코딩언어셋) 반환 (IE9 이상)
DOM_Document JS - lastModified 속성 - 최종수정시간 (= 마지막수정시간) 반환 [읽기전용]
DOM_Document JS - links 속성 - href 속성 갖은 (앵커태그 + 에어리어태그) 링크태그집합
DOM_Document JS - normalize() 메서드 - 공백제거후, 인접텍스트노드 합치기 (document경우)
DOM_Document JS - normalizeDocument() 메서드 - normalize() 메소드와 유사 (지원 X)
DOM_Document JS - open() 메서드 - 출력모드 열기
DOM_Document JS - querySelector() 메서드 ★ - 쿼리선택자 (= 문서 안 지정 선택자 중 첫번째 것만 =…
DOM_Document JS - querySelectorAll() 메서드 ★★★ - 일치요소 모두 선택 (= querySelecto…
DOM_Document JS - readyState 속성 - 현재웹문서 로딩상태 반환 (= readyState속성 = 레디스테이트속…
DOM_Document JS - referrer 속성 ★ - 접속경로 (= 리퍼러) 반환
DOM_Document JS - removeEventListener() 메서드 ★ - 이벤트핸들러를 웹문서에서 제거 (IE9 이상)
DOM_Document JS - renameNode() 메서드 - Element 및 Attr 유형의 노드 이름 변경 (지원 X)
DOM_Document JS - scripts -모든 스크립트태그 모음
DOM_Document JS - strictErrorChecking 속성 - 엄격한오류검사 설정/반환 (= 엄격한에러체크 = 스트릭…
DOM_Document JS - title - 타이틀 (=문서제목) 설정/반환
DOM_Document JS - document.URL 속성 - 웹문서주소 (= document.URL속성 = 다큐먼트유알엘속성/도…
DOM_Document JS - write() 메서드 - 내용쓰기 (= 내용입력) : 줄바꿈 X
DOM_Document JS - writeln() 메서드 - 내용쓰기 (= 내용입력) : 줄바꿈 X (= writeln메서드 = 라…
26/67
목록
찾아주셔서 감사합니다. Since 2012