>웹 프론트엔드 >JS 튜토리얼 >Javascript 트랩 창 전역 object_javascript 기술

Javascript 트랩 창 전역 object_javascript 기술

WBOY
WBOY원래의
2016-05-16 18:58:131045검색

function Test(){
this.name='Test';
var name=2;
this.show=function(){
alert(name); name);//표시 이름
}
}
var test=new Test();//생성자를 통해 객체 생성
test.show();//출력 2 및 'Test ' , 객체 메서드가 해당 속성에 액세스할 때 이를 추가해야 함을 나타냅니다.

function Test2(){
this.name='Test2'
this.show=function(){
경고(이름);
alert(this.name);
}
}
Test();//Test()를 직접 호출합니다.
var test2=new Test2(); 🎜 >test2.show();//Test와 Test2가 출력되는군요. name 값이 무엇인가요? 그런데 왜 'Test'인가요?
alert(name); show(); //출력 2, test; 왜 버그인가요?

//출력 2, 테스트

/ / ff와 ie6 모두에서 실행 결과가 동일합니다. 버그는 아닌 것 같습니다.
// 참고: 객체 메소드가 해당 객체의 속성에 액세스할 때 | , 기본값은 창 개체의 메서드입니다.
//함수를 직접 호출하는 것은 윈도우를 통해 메소드를 호출하는 것과 동일합니다. 그러면 메소드 내부의 this는 당연히
//window 객체이고, this.name='Test'는 윈도우에 속성을 추가합니다. object.
// 메소드의 로컬 범위에 name이 정의되어 있지 않고 경고(name)를 호출하는 것은 경고(window.name)를 호출하는 것과 동일합니다.
/*아, 코드가 혼란스럽습니다. . 이것은 심각한 함정인 것 같습니다! ! */

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