> 웹 프론트엔드 > JS 튜토리얼 > 자바스크립트 변수 선언_javascript 스킬에 대한 자세한 설명

자바스크립트 변수 선언_javascript 스킬에 대한 자세한 설명

WBOY
풀어 주다: 2016-05-16 16:30:09
원래의
1457명이 탐색했습니다.

함수 몸체 외부에서 정의된 것은 전역 변수이고, 함수 몸체 내부에서 정의된 것은 지역 변수입니다. 여기서 정의는 var를 통한 선언을 의미합니다.

JavaScript에는 암시적 전역 개념이 있습니다. 즉, 선언하지 않은 모든 변수는 전역 개체 속성이 됩니다. 예:

코드 복사 코드는 다음과 같습니다.

함수 테스트(){
내 이름 = "흥얼흥얼";
경고(내 이름);
}
test(); // "윙윙거리는 소리"
경보(내 이름); //"윙윙"

두 결과가 동일하여 myname이 전역 변수임을 나타냅니다.

그렇다면 암시적 전역 변수와 명시적으로 정의된 전역 변수 사이에 차이점이 있나요? . 대답은 '예'입니다. 아래 예를 살펴보세요.

코드 복사 코드는 다음과 같습니다.

// 세 개의 전역 변수를 정의합니다
var global_test1 = 1;
global_test2 = 2; // 네거티브 교재
(함수 () {
Global_test3 = 3; //네거티브 교재
}());
// 삭제 시도
global_test1 삭제; // 거짓
global_test2 삭제; // 참
global_test3 삭제; // 참
// 삭제 테스트
Alert(typeof global_test1); // "번호"
Alert(typeof global_test2); // "정의되지 않음"
경고(typeof global_test3); // "정의되지 않음"

위의 예에서 볼 수 있듯이 함수 외부에서 var로 정의된 global_test1은 삭제할 수 없으며, var로 정의되지 않은 global_test2, global_test3은 (함수 본문 내에서 생성 여부와 상관없이) 삭제됩니다.

요약하면 함수 외부에서 var를 통해 선언된 전역 변수는 삭제할 수 없지만 묵시적인 전역 변수는 삭제할 수 있습니다.

여기서 주목해야 할 점은 JavaScript에는 "호이스팅"(일시 중지/상위 구문 분석/사전 구문 분석)이라는 동작이 있다는 것입니다.

예를 들어 설명하겠습니다.

코드 복사 코드는 다음과 같습니다.

var myname = "huming"; //전역변수 선언
함수 테스트() {
경고(내 이름);
var myname = "local_huming";
경고(내 이름);
}
테스트();

두 알림의 내용이 같다고 생각하시나요? ? 분명히 일관성이 없고 일관성이 있다는 것은 말할 필요도 없습니다. . 실제 출력은 "정의되지 않음", "local_huming"입니다.

위의 예는

과 동일합니다.

코드 복사 코드는 다음과 같습니다.

var myname = "huming"; //전역변수 선언
함수 테스트() {
var myname;
경고(maname);
myname = "local_huming";
경고(내 이름); // "로컬"
}
테스트();

첫 번째 경고에서 출력되는 myname은 여러분이 생각하는 전역 변수가 아니라, 동일한 범위(함수 본문)에 있는 지역 변수입니다. 선언되지는 않았지만 그렇게 처리됩니다. 이것을 "호이스팅"이라고 합니다.

이 점을 분명히 해야 합니다. 함수 본문에 변수를 사용하고 나중에 다시 선언하면 오류가 발생할 수 있습니다.

작성규격 :

코드 복사 코드는 다음과 같습니다.

함수 테스트() {
var a = 1,
b = 2,
        c = a b,
      d = {},
        전자,
         f;
// 함수 본문...
}

혜택은 다음과 같습니다.

1. 쉬운 검색을 위해 모든 지역 변수는 함수 시작 부분에 정의됩니다.

2. 변수를 정의하기 전에 사용할 때 논리적 오류를 방지합니다.

JavaScript의 변수 선언을 이해하셨나요? 위의 내용은 매우 자세하고 이해하기 쉽습니다.

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿