자바스크립트 변수 선언문은 어디에 나타나더라도 다른 코드보다 먼저 실행됩니다. var 키워드를 사용하여 선언된 변수의 범위는 주변 함수일 수 있는 현재 실행 컨텍스트이거나, 변수가 함수 본문 외부에서 선언된 경우 전역 변수입니다.
함수 몸체 외부에서 정의된 것은 전역 변수이고, 함수 몸체 내부에서 정의된 것은 지역 변수입니다. 여기서 정의는 var를 통한 선언을 의미합니다.
JavaScript에는 암시적 전역 개념이 있습니다. 즉, 선언하지 않은 모든 변수는 전역 개체 속성이 됩니다. 예:
function test(){ myname = "huming"; alert(myname); } test(); // "huming" alert(myname); //"huming"
두 결과가 동일하여 myname이 전역 변수임을 나타냅니다.
그렇다면 암시적 전역 변수와 명시적으로 정의된 전역 변수 사이에 차이점이 있나요? . 대답은 '예'입니다. 아래 예를 살펴보세요.
// 定义三个全局变量 var global_test = ; global_test = ; // 反面教材 (function () { global_test = ; // 反面教材 }()); // 试图删除 delete global_test; // false delete global_test; // true delete global_test; // true // 测试该删除 alert(typeof global_test); // "number" alert(typeof global_test); // "undefined" alert(typeof global_test); // "undefined"
위의 예에서 볼 수 있듯이 함수 외부에서 var로 정의된 global_test1은 삭제할 수 없으며, var로 정의되지 않은 global_test2와 global_test3은 (함수 본문 내에서 생성 여부와 상관없이) 삭제됩니다.
요약하면 함수 외부에서 var를 통해 선언된 전역 변수는 삭제할 수 없지만 묵시적인 전역 변수는 삭제할 수 있습니다.
여기서 주목해야 할 점은 JavaScript에는 "호이스팅"(일시 중지/상위 구문 분석/사전 구문 분석)이라는 동작이 있다는 것입니다.
예를 들어 설명하겠습니다.
var myname = "huming"; //声明全局变量 function test() { alert(myname); var myname = "local_huming"; alert(myname); } test();
두 알림의 내용이 일치한다고 생각하시나요? ? 분명히 일관성이 없고 일관성이 있다는 것은 말할 필요도 없습니다. . 실제 출력은 "정의되지 않음", "local_huming"입니다.
위의 예는
과 동일합니다.var myname = "huming"; //声明全局变量 function test() { var myname; alert(maname);<br> myname = "local_huming"; alert(myname); // "local" } test();
첫 번째 경고에서 출력되는 myname은 여러분이 생각하는 전역 변수가 아니라, 동일한 범위(함수 본문)에 있는 지역 변수입니다. 선언되지는 않았지만 그렇게 처리됩니다. 이것을 "호이스팅"이라고 합니다.
이 점을 분명히 해야 합니다. 함수 본문에 변수를 사용하고 나중에 다시 선언하면 오류가 발생할 수 있습니다.
작성규격 :
function test() { var a = , b = , c = a + b, d = {}, e, f; // function body... }
혜택은 다음과 같습니다.
1. 쉬운 검색을 위해 모든 지역 변수는 함수 시작 부분에 정의됩니다.
JavaScript에서는 변수 이름이 범위에 들어가는 방법이 네 가지가 있습니다.
언어 내장, 모든 범위에는 this 및 인수 키워드가 있습니다
위에 나열된 네 가지 순서도 우선순위가 높은 것부터 낮은 것입니다. 변수 이름이 선언되면 다른 우선순위가 낮은 변수 선언 형식으로 덮어쓸 수 없습니다.