>웹 프론트엔드 >JS 튜토리얼 >Javascript var 변수 암시적 선언 방법에 대한 자세한 설명

Javascript var 변수 암시적 선언 방법에 대한 자세한 설명

怪我咯
怪我咯원래의
2017-07-06 11:32:501922검색

JavaScript에서는 var를 사용하여 변수를 선언하지만 이 구문은 꼭 필요한 것은 아닙니다. 때로는 var로 선언하지 않고 변수를 직접 사용할 수도 있습니다.

그리고 등등. 예를 들어, 코드의 특정 줄에서 선언된 변수 x를 사용하려고 합니다. 결과적으로 입력 오류 또는 철자 오류로 인해 변수가 y로 기록됩니다. 암시적" 변수 선언.y, 실제

프로그래밍 프로세스에서는 이러한 종류의 오류를 찾기 어려울 때가 있습니다. 그리고 오늘은 동료의 소개를 통해 이 '암시적 선언'에 또 다른 문제점이 있다는 것을 알게 되었습니다.
현재 컨텍스트에서 이 "암시적" 선언을 수행하면 JavaScript 엔진은 먼저 현재 컨텍스트에서 이 변수가 이전에 선언되었는지 검색한 다음 이전 컨텍스트로 이동하여 찾습니다. 아직 선언되지 않았습니다. 발견되면 이 변수가 최종적으로 창에 선언됩니다!
예:

코드는 다음과 같습니다.

window. y = "hello"; 
function func(){ 
y = "OH, NO!!!"; 
} 
func(); 
alert(window.y); //#=> display "OH, NO!!!"

컨텍스트의 레이어에 이러한 "암시적으로" 정의된 변수가 있는 경우 창 변수에 새 변수를 생성하지 않고 해당 레이어의 변수가 수정됩니다. . (이러한 종류의 버그는 상당히 성가시며, 특히 캡슐화된 더 복잡한 코드는 더욱 그렇습니다.)

예:

코드는 다음과 같습니다:

var x = "window.x"; 
function a() { 
var x = "a's x"; 
var b = function() { 
var c = function() { 
//no var! 
x = "c's x:"; 
}; 
alert("before c run,the b.x:" + x); 
c(); 
alert("after c run, the b.x:" + x); 
}; 
alert("a.x is:" + x); 
b(); 
alert("after b function runed, the a.x is:" + x); 
}; 
alert("before a run, window.x:" + x); 
a(); 
alert("after a run, window.x:" + x);

다음과 같은 레이어가 있습니다: window, func a, func b, func c는 다음과 같습니다. 항상 중첩된 레이어로 사용됩니다. window->a->b->c

window와 a는 모두
정의된 변수 x를 갖고 있고, 변수는 b에 정의되어 있지 않으며, x는 c에 '암시적으로' 선언되어 있고, x는 결국 수정됨 변수의 값입니다. JavaScript에서는 변수를 선언할 때 변수 앞에 var를 추가해야 한다는 점을 기억하세요.

위 내용은 Javascript var 변수 암시적 선언 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.