자바스크립트에서 변수는 값과 연관된 이름으로서, 변수를 이용하면 자바스크립트 프로그램에서 데이터를 저장하고 조작할 수 있다.
변수는 var 키워드로 선언한다.
동일한 var 키워드를 이용해 여러 개의 변수를 선언할 수 있으며, 변수를 선언함과 동시에 초기화할 수도 있다. 다음 예제를 보자.
var x; var y = 10; var a, b, c; var i = 10, j = 10, k = 10;
변수에 초기값을 지정하지 않으면 해당 초기값은 undefined가 된다.
var x; console.log(x); //undefined
자바스크립트는 다른 자바나 C 같은 어어와 달리 명시적인 타입이 없다. 자바스크립트 변수는 어떤 자료형의 값도 담을 수 있으며, 한 변수를 다른 타입의 값으로 할당할 수 있다.
var id = 10; // number id = "ten"; // string console.log(id); // ten
자바스크립트 변수 유효범위는 변수를 어디에서 접근할 수 있느냐를 가리킨다.
전역 변수와 지역 변수의 예는 다음과 같다.
var name = "global"; // 전역 변수를 선언 function checkscope(){ var name = "local"; // 지역 변수를 선언 console.log(name); // 전역 변수가 아닌 지역 변수를 사용 } checkscope(); // 출력 결과: "local"
var 키워드 없이 변수를 선언하면 자동으로 전역 변수가 된다.
var name = "global"; // 전역 변수를 선언 function checkscope(){ name = "local"; // 전역 변수를 변경 name2 = "local"; // 암묵적으로 새 전역 변수가 선언됨 } checkscope(); console.log(name); // output: "local" console.log(name2); // output: "local"
참고: 모든 변수를 var 키워드로 선언한다.
중첩 함수에서 내부 함수는 그것이 담긴 함수의 변수에 접근할 수 있다.
function changeName(name){ // "name"은 지역 변수다 function inner1(){ name = name + "-inner1"; function inner2(){ name = name + "-inner2"; } inner2(); } inner1(); return name; } console.log(changeName("Hello")); // Hello-inner1-inner2
다른 자바나 C 같은 언어와 달리 블록({}) 안에서 선언된 변수는 해당 블록이 닫힌 이후에도 접근할 수 있다. 다음 예제를 보자.
{ var count = 10; } console.log(count); // 10
아울러 반복문 내에서 선언된 변수도 해당 반복문이 끝난 이후에 접근할 수 있다.
for (var i=0; i<11; i++){} console.log( i ); // 11
← 이전 | 홈 | 다음 → |