글로벌 변수와 로컬 변수
글로벌 변수와 로컬 변수에 대해서 알아보겠습니다.
보통 글로벌 변수를 전역변수, 로컬변수는 지역변수 라고 하는데요.
저는 전역 변수와 지역변수라는 말을 들을때 단어 자체에 경기를 일으켜서 글로벌 변수와 로컬변수라고 하겠습니다.
다른곳에서는 지역변수, 전역 변수 라는 명칭을 사용하면 아하! 하면서 글로벌 변수, 로컬 변수 라고 생각나시면 됩니다.
우선 글로벌 변수와 로컬 변수에 설명하기 앞서 함수에 대해서 알아봅시다.
f(x)아시죠. 몰라도 됩니다.
음.. 어떤 특정한 행동을 하게끔 하기위해 함수를 선언하여 그 함수 안에 특정한 행동을 입력하는데요.
function function_name(){ }
위의 소스가 함수를 선언하는 소스 입니다.
우선 함수 선언을 위해 funciton을 적은후 함수의 이름을 적어 줍니다. 그리고 괄호를 열고 닫고 그 후 대괄호를 열고 닫고 해주며 대괄호 안에 실행할 명령문들을 적습니다.
예를 들어 함수의 이름을 ipad라고 해봅시다.
function ipad(){ }
위와 같이 function 후에 ipad를 적고 괄호를 열고 닫고 그후 대괄호를 열고 닫고 합니다. 그럼 ipad라는 함수가 생성된것입니다.
함수를 생성을 했는데 위와 같이 실행을 한다면 과연 실행이 될까요. 안됩니다. 함수를 따로 호출을 해야 하는데요 함수를 호출할때는 함수명(); 입니다.
함수 호출
함수명(); 예를 들어 위와 같이 ipad라는 함수를 만들었다면 ipad(); <== 입니다.
소스를 통하여 테스트 해봅시다.
우선 함수를 만들어 봅시다. 함수는 hello world를 출력하는 함수 입니다.
function hello(){ document.write("Hello world"); }
아래의 소스는 함수는 만들었으나 함수를 호출하는 코드는 없습니다. 결과를 통하여 한번 체험 해보세요. 결과가 아무것도 안나오면 정상입니다.
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>자바스크립트</title> <script> function hello(){ document.write("Hello world"); } </script> </head> <body> </body> </html>
위의 소스를 타이핑 해보시거나 이 소스를 웹에서 보기 버튼을 눌러 테스트를 해보시면 결과 화면에 아무것도 안나오는 것을 알 수 있습니다.
그럼 다음의 함수 호출문을 사용하여 결과를 확인해 봅시다.
hello();
위의 소스는 hello라는 함수를 호출하는 함수 입니다. 그럼hello라는 함수가 호출되므로 hello함수 안에 있는 출력문이 실행합니다.
봅시당
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>자바스크립트</title> <script> function hello(){ document.write("Hello world"); } hello(); </script> </head> <body> </body> </html>
위 소스의 결과를 보면 hello함수가 작동하여 hello world라는 문구가 출력하는 것을 볼 수 있습니다.
지금은 글로벌 변수와 로컬 변수에 대해서 알아보는 시간이기 때문에 함수에 대한 설명은 여기서 마치겠습니다. ^-^
다시 정신을 차리고 글로벌 변수, 로컬 변수
var
var는 변수를 선언할때 사용합니다.
변수 선언할때 var 변수명 = 변수의 값;
var를 붙이지 않아도 사용 가능 합니다.
일단 글로벌 변수와 로컬 변수는 이름에서 보듯이 글로벌 변수는 어디에서나 사용 가능한 변수이며 로컬 변수는 특정 지역에서만 사용하는 변수 입니다.
여기에서 말하는 특정지역은 함수를 말합니다. 자신이 만든 특정한 함수 안에서만 활동하는 함수는 로컬 함수로 함수 밖에서는 사용을 못하지요. 하지만 글로벌 함수는 이 함수 저함수 함수가 아닌곳에서도 사용이 가능 하답니다.
이해하기 쉽도록 제가 css를 이용하여 한번 만들어 보도록 하겠습니다.
<html>
<head>
<title>웹 에디터에서 제이쿼리 예제가 구동이 안될시에는 파이어폭스(권장) 또는 인터넷 익스플로러를 이용해주세요.</title>
<script>
function hello(){
document.write(hello);
</head>
<body>
</body>
</html>
빨간색 영역은 글로벌 변수가 인식되는 공간입니다. 그래서 이름도 글로벌(전역)변수입니다. ^-^
파란색 영역은 로컬 변수가 인식되는 공간입니다. 함수 내에서만 위력을 발휘하네요. 그래서 로컬(지역)변수입니다. ^-^
위의 내용만으로는 잘 알 수 없으니 직접 변수를 함수 밖과 함수 안에서 선언하여 테스트를 해봅시다.
아래의 소스는 글로벌 변수 glo_var을 선언하고 함수 안에 로컬변수 local_var을 선언 해서 함수 밖에 출력문을 이용하여 glo_var 변수를 출력하는 예제입니다.
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>자바스크립트</title> <style type="text/css"> </style> <script type="text/javascript"> glo_var = 10; function hello(){ local_var = 20; } document.write(glo_var); </script> </head> <body> </body> </html>
위의 소스를 실행해보면 변수 glo_var의 값인 10이 출력되는걸 보실 수 있습니다.
그럼 위의 소스에서 출력문의 변수를 로컬 변수로 변경하여 값이 출력 되는지 안되는지 한번 해봅시다.
결과는 당연히 로컬변수이기 때문에 출력이 안됩니다만 그래도 눈으로 보고 이해를 해봅시다.
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>자바스크립트</title> <style type="text/css"> </style> <script type="text/javascript"> glo_var = 10; function hello(){ local_var = 20; } document.write(local_var); </script> </head> <body> </body> </html>
위의 소스를 실행 해보면 결과에 아무것도 출력이 안되는걸 보실 수 있습니다. 그 이유는 로컬 변수를 해당 함수 밖에서 실행을 했기 때문이죠. ^^
함수 안에서 변수명 앞에 var를 붙인것과 안붙인것의 차이.
함수 밖에서의 글로벌 변수 앞에 var을 붙이건 안붙이건 글로벌 변수 입니다만,
함수 안에서는 다릅니다.
로컬 변수 앞에 var가 있다면 그 로컬변수는 함수 안에서만 작동하지만,
로컬 변수 앞에 var가 없다면 해당 함수가 한번 호출 된 이후에는 글로벌 변수가 된다.
다음 예제를 통하여 확인해 봅시다.
아래의 예제는 var가 붙지 않은 변수인 local_var2 변수를 함수 밖에서 출력을 하는 예제입니다.
var가 붙지 않는 변수는 한번 그 함수를 호출 한다면 글로벌 변수가 되는데요. 아래의 소스에는 hello 함수를 호출하는 부분이 없으므로 결과는 출력이 되지 않겠죠? ^^
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>자바스크립트</title> <style type="text/css"> </style> <script type="text/javascript" src="https://code.jquery.com/jquery-3.2.0.min.js" ></script> <script type="text/javascript"> glo_var = 10; function hello(){ var local_var = 20; local_var2 = 30; } document.write(local_var2); </script> </head> <body> </body> </html>
아래의 소스는 위의 소스에서 함수 호출 부분인 hello()를 함수 밖에 선언한 것입니다. 함수를 호출 하므로써 local_var2 변수는 글로벌 변수가 되므로 결과값을 보여줍니다.^^
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>자바스크립트</title> <style type="text/css"> </style> <script type="text/javascript" src="https://code.jquery.com/jquery-3.2.0.min.js" ></script> <script type="text/javascript"> glo_var = 10; function hello(){ var local_var = 20; local_var2 = 30; } hello(); document.write(local_var2); </script> </head> <body> </body> </html>
보시면 결과값이 보이죠.^^ 이걸로 글로벌변수와, 로컬 변수에 관한 강좌를 마치겠습니다. ^^