Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 오라클
- 자바스크립트
- 자바스크립트 API
- 파이썬
- numpy
- 자바스크립트 객체
- 카카오프로젝트 100
- 카카오프로젝트
- 깃허브
- 자바스크립트 prototype
- 자바스크립트 기본 문법
- 다크웹
- php
- Oracle SQL
- 보안뉴스
- 보안뉴스요약
- 랜섬웨어
- 자바스크립트 jQuery
- python
- 보안뉴스 한줄요약
- oracle db
- oracle
- 카카오프로젝트100
- ES6
- 자바스크립트 element api
- 보안뉴스한줄요약
- javascript
- GIT
- 자바스크립트 node
- 보안뉴스 요약
Archives
- Today
- Total
FU11M00N
[ JavaScript ] JS Hosting이란? 본문
- Hosting
변수나 함수의 선언문을 유혀범위의 최상단으로 올려 변수나 함수를 선언하기 이전에도 사용할 수 있도록 해주는것입니다.
- 변수 Hosting
console.log(test); // 결괏값: undefined
var test = "FU11_M00N";
console.log(test); // 결괏값: FU11_M00N
name이라는 변수가 선언되기 전에 호출하면 에러가 아닌 undefined를 출력합니다.
var test;
console.log(test); // 결괏값: undefined
test = "FU11_M00N";
console.log(test); // 결괏값: FU11_M00N
자바스크립트의 Hoisting 특성은 유효범위의 최상단으로 올리기때문에 위의 예제와 동일한 효과가 발생합니다.
- 함수 Hoisting
test();
function test() {
console.log(hello); // 결과 : undefined
var hello = 'test';
console.log(hello); // 결과 : test
}
함수 또한 선언되기 전에 사용 가능합니다.
test(); // Uncaught TypeError: test is not a function 에러
var test = function() {
console.log(hello); // 결과 : undefined
var hello = 'test';
console.log(hello); // 결과 : test
}
하지만 위의 예제처럼 함수를 변수에 넣어 사용하면 함수 Hoisting이 발생하지않고 에러가 발생하게 됩니다.
'SUA 정보보안 > JavaScript' 카테고리의 다른 글
[ JavaScript ] JS 호출스택 , 이벤트 루프 (0) | 2021.03.06 |
---|---|
[ JavaScript ] JS jQuery Ajax (0) | 2021.02.10 |
[ JavaScript ] JS JSON이란? (feat. Ajax) (0) | 2021.02.10 |
[ JavaScript ] JS Ajax XMLHttpRequest 사용 (0) | 2021.02.10 |
[ JavaScript ] JS jQuery 이벤트 (on API,이벤트 제거 , late binding selector, 다중 바인딩) (0) | 2021.02.10 |
Comments