> 백엔드 개발 > PHP 튜토리얼 > javascript - JS의 객체 범위는 무엇입니까? 아니면 객체의 속성에 대한 몇 가지 질문이 있습니까?

javascript - JS의 객체 범위는 무엇입니까? 아니면 객체의 속성에 대한 몇 가지 질문이 있습니까?

WBOY
풀어 주다: 2016-08-23 09:17:41
원래의
1085명이 탐색했습니다.

<code>var a=3;
var object = { 
    a:2, 
    run: function() {
         alert(a);         //a=3;
         } 
    }; 
object.run(); </code>
로그인 후 복사
로그인 후 복사

왜 not 2인가요?
객체에 있는 a:2는 무엇을 의미하나요?

답글 내용:

<code>var a=3;
var object = { 
    a:2, 
    run: function() {
         alert(a);         //a=3;
         } 
    }; 
object.run(); </code>
로그인 후 복사
로그인 후 복사

왜 not 2인가요?
객체에 있는 a:2는 무엇을 의미하나요?

<code>run: function() {
     this.a=1;
     } 
}; </code>
로그인 후 복사

명시적으로 지정하지 않으면 여전히 전역 범위의 변수입니다.

<code class="javascript">var a=3;
var object = { 
    a:2, 
    run: function() {
         alert(this.a);//2
         alert(a);//3 
        } 
    }; 
object.run(); </code>
로그인 후 복사

범위의 문제입니다. 이때 프로그램은 먼저 a를 찾습니다. 찾지 못하면 외부에서 찾습니다. , 그러면 var a를 찾습니다. 이것은 실제로 window.a와 동일합니다. 실제로 여기에서 a를 직접 팝업하는 것은 window.a의 전역 범위에서 a를 찾는 것과 같습니다. object.a가 찾고 있는 것이 아닌가요? 앞서 언급했듯이 obejct.a가 아닌 window.a와 같습니다. 둘의 범위 환경이 다릅니다. 객체지향 프로그래밍 언어로서 js는 모든 것이 속할 장소가 있어야 합니다. 이를 이해하지 못한다면 일반적으로 js가 모든 것을 소유한다는 것을 인정하는 것과 같습니다. 창 아래에 정의되어 있습니다. 따라서 어떤 a가 먼저인지 정의하지 않으면 a는 창에 직접 속하는 것과 같습니다. 물론, 함수 아래에 정의된 내용은 함수의 범위에 속하는 것과 동일합니다. 자세히 말할 것은 많지 않습니다. 더 많은 정보를 읽어보세요.

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