> 웹 프론트엔드 > JS 튜토리얼 > JavaScript_Basic 지식의 이 메커니즘

JavaScript_Basic 지식의 이 메커니즘

WBOY
풀어 주다: 2016-05-16 15:16:51
원래의
1225명이 탐색했습니다.

JavaScript에는 상황에 따라 이를 가리키는 자체 메커니즘이 있습니다.

글로벌 범위

console.log(this); //全局变量
로그인 후 복사

전역 범위는 이를 사용하여 브라우저 환경의 창인 전역 변수를 가리킵니다.

참고: ECMAScript5의 엄격 모드에는 전역 변수가 없으며 여기서는 정의되지 않았습니다.

함수 호출

function foo() {
  console.log(this);
}

foo(); //全局变量

로그인 후 복사

함수 호출에서도 이는 전역 변수를 가리킵니다.

참고: ECMAScript5의 엄격 모드에는 전역 변수가 없으며 여기서는 정의되지 않았습니다.

객체 메서드 호출

var test = {
  foo: function () {
    console.log(this);
  }
}

test.foo(); //test对象

로그인 후 복사

객체 메서드 호출에서 이는 호출자를 가리킵니다.

var test = {
  foo: function () {
    console.log(this);
  }
}

var test2 = test.foo;
test2(); //全局变量

로그인 후 복사

그러나 이 함수의 지연 바인딩 기능으로 인해 위의 예에서는 함수를 직접 호출하는 것과 동일한 전역 변수를 가리킵니다.

동일한 코드 세그먼트는 실행 시에만 확인할 수 있다는 점이 매우 중요합니다.

생성자

function Foo() {
  console.log(this);
}

new Foo(); //新创建的对象
console.log(foo); 

로그인 후 복사

생성자 내부에서 새로 생성된 개체를 가리킵니다.

명시적으로 설정

function foo(a, b) {
  console.log(this);
}

var bar = {};

foo.apply(bar, [1, 2]); //bar
foo.call(1, 2); //Number对象

로그인 후 복사

Function.prototype의 호출 또는 적용 메소드를 사용하는 경우 함수 내부의 이것이 전달된 첫 번째 매개변수로 설정됩니다.

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