>웹 프론트엔드 >JS 튜토리얼 >JS의 this 포인터와 호출 및 적용 기능

JS의 this 포인터와 호출 및 적용 기능

青灯夜游
青灯夜游앞으로
2018-10-08 16:25:472032검색

이 글은 기본적인 JS 콘텐츠인 이 포인터와 관련 지식 포인트를 공유하고 관심 있는 친구들이 배우고 참고할 수 있습니다.

특정 실제 응용에서는 함수를 정의할 때 이것의 요점을 결정할 수 없지만, 실행 환경에 따라 대략 다음 세 가지 유형으로 나눌 수 있습니다.

1 . 함수가 일반 함수로 호출될 때 전역 객체를 가리킵니다

2. 함수가 객체의 메소드로 호출될 때 이것은 객체를 가리킵니다.3. 생성자, 이것은 새로 생성된 개체를 가리킵니다


예제 1:

window.name = 'myname';
function getName() {
  console.log(this.name);
}
getName(); //输出myname
예제 2:

var boy = {
  name: 'Bob',
  getName: function() {
    console.log(this.name);
  }
}
boy.getName(); //输出Bob
예제 3:

function Boy(name) {
  this.name = name;
}
var boy1 = new Boy('Bob');
console.log(boy1.name); //输出Bob
예제 3에는 또 다른 특별한 경우가 있습니다. 즉, 생성자가 "return"을 통해 객체를 반환할 때, 이 연산의 최종 결과는 새로 생성된 객체가 아닌 이 객체를 반환하므로 이 경우에는 쓸모가 없습니다.


예 4:

function Boy(name) {
  this.name = name;
  return { //返回一个对象
    name: 'Jack'
  }
}
var boy1 = new Boy('Bob');
console.log(boy1.name); //输出Jack
예 5:

function Boy(name) {
  this.name = name;
  return 1; //返回非对象
}
var boy1 = new Boy('Bob');
console.log(boy1.name); //输出Bob

호출 및 적용의 역할

apply는 함수 본문에서 this의 포인터를 두 개 지정합니다. 두 번째 매개변수 첫 번째 매개변수는 호출된 함수의 매개변수 목록을 전달하는 데 사용되는 배열 또는 배열과 유사한 매개변수입니다.


예제 1:

function getInfo() {
  console.log(this.name+' like '+arguments[0]+' and '+arguments[1]);
}
var boy1 = {
  name: 'Bob',
  age: 12
}
getInfo.apply(boy1,['sing','swimming']); //输出Bob like sing and swimming
call 전달된 매개변수의 개수는 고정되어 있지 않습니다. apply와 마찬가지로 첫 번째 매개변수도 두 번째 매개변수부터 시작하여 함수 본문에서 this의 포인터를 지정하는 데 사용됩니다. , 각 매개변수는 호출된 함수에 차례로 전달됩니다.


예 2:

function getInfo() {
  console.log(this.name+' like '+arguments[0]+' and '+arguments[1]);
}
var boy1 = {
  name: 'Bob',
  age: 12
}
getInfo.call(boy1,'sing','shopping'); //输出Bob like sing and shopping
게다가 대부분의 고급 브라우저는 바인딩 메서드도 구현합니다. 호출과 적용의 차이점은 바인딩이 함수 내에서 이 포인터만 변경하지만 실행되지는 않는다는 것입니다. 즉시 통화를 표시해야 합니다.


예제 3: 브라우저의 바인딩 방법 시뮬레이션

Function.prototype.bind = function(obj){
  var self = this;
  return function(){
    return self.apply(obj,arguments);
  }
};
var obj = {
  name: 'Bob',
  age: 12
};
var func = function(){
  console.log(this.name+' like '+arguments[0]+' and '+arguments[1]);
}.bind(obj);
func('sing','shopping');

Lost this

어떤 경우에는 this에 대한 포인터가 손실될 수 있습니다. 이 때 call, Apply 및 바인딩을 사용해야 합니다. 이것의 포인팅 문제를 변경하십시오.

예제 1: "boy" 객체의 속성으로 "getName" 메소드를 호출하면, 다른 변수가 "getName" 메소드를 참조하는 경우에는 "boy" 객체를 가리키는 것입니다. 일반 함수, 이것은 전역 개체 창을 가리킵니다

var boy = {
  name: 'Bob',
  getName: function() {
    console.log(this.name);
  }
}
boy.getName(); //输出Bob
var getBoyName = boy.getName;
getBoyName(); //输出undefined

예 2: 함수 내부에 함수가 정의되어 있어도 일반 개체라고 하면 이것도 창 개체를 가리킵니다

var boy1 = {
  name: 'Bob',
  age: 12,
  getInfo: function() {
    console.log(this.name);
    function getAge() {
      console.log(this.age);
    }
    getAge();
  }
}
boy1.getInfo(); //Bob
        //undefined

위 내용은 전체 내용입니다 더 많은 관련 튜토리얼을 보려면

JavaScript 비디오 튜토리얼

을 방문하세요!

위 내용은 JS의 this 포인터와 호출 및 적용 기능의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 jb51.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제