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

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

Oct 08, 2018 pm 04:25 PM
apply this

이 글은 기본적인 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Java Fluent Mybatis 집계 쿼리 및 메소드 적용 프로세스 예시 분석 Java Fluent Mybatis 집계 쿼리 및 메소드 적용 프로세스 예시 분석 May 22, 2023 pm 01:31 PM

데이터 준비: 쿼리 조건을 집계하기 위해 여러 데이터가 추가됩니다. MIN 우리는 최소 연령을 얻으려고 노력합니다. 메서드 구현 @OverridepublicIntegergetAgeMin(){Mapresult=testFluentMybatisMapper.findOneMap(newTestFluentMybatisQuery().select.min.age("minAge").end()).orElse(null);returnresult!=null?Convert.toInt(result.get (&qu

Vue2가 이를 통해 다양한 옵션의 속성에 접근할 수 있는 이유에 대해 이야기해보겠습니다. Vue2가 이를 통해 다양한 옵션의 속성에 접근할 수 있는 이유에 대해 이야기해보겠습니다. Dec 08, 2022 pm 08:22 PM

이 글은 Vue 소스 코드를 해석하는 데 도움이 될 것이며 이를 사용하여 Vue2의 다양한 옵션에서 속성에 액세스할 수 있는 이유를 소개하는 것이 모든 사람에게 도움이 되기를 바랍니다!

이 점을 이해하고 프론트엔드 70%를 따라잡는 글 이 점을 이해하고 프론트엔드 70%를 따라잡는 글 Sep 06, 2022 pm 05:03 PM

Vue2의 이 포인팅 문제로 인해 동료가 버그로 인해 화살표 기능이 사용되어 해당 소품을 얻을 수 없게 되었습니다. 제가 그에게 소개했을 때 그는 그것을 몰랐고, 그래서 저는 일부러 프론트엔드 커뮤니케이션 그룹을 살펴보았습니다. 지금까지 적어도 70%의 프론트엔드 프로그래머들은 오늘 그것을 이해하지 못하고 있습니다. 모든 것이 불분명하다면 이 링크를 아직 배우지 않았다면 큰 소리로 말해주세요.

jQuery에서 이 키워드를 사용하는 영리한 방법 jQuery에서 이 키워드를 사용하는 영리한 방법 Feb 25, 2024 pm 04:09 PM

jQuery에서 this 키워드의 유연한 사용 jQuery에서 this 키워드는 현재 조작 중인 DOM 요소를 참조하는 데 사용되는 매우 중요하고 유연한 개념입니다. 이 키워드를 합리적으로 사용함으로써 페이지의 요소를 쉽게 조작하고 다양한 인터랙티브 효과와 기능을 얻을 수 있습니다. 이 기사에서는 특정 코드 예제를 결합하여 jQuery에서 이 키워드를 유연하게 사용하는 방법을 소개합니다. 간단한 이 예 먼저 간단한 이 예를 살펴보겠습니다. 우리가

이게 뭔가요? JavaScript에서 이에 대한 심층 분석 이게 뭔가요? JavaScript에서 이에 대한 심층 분석 Aug 04, 2022 pm 05:02 PM

이게 뭔가요? 다음 기사에서는 JavaScript에서 이에 대해 소개하고 다양한 함수 호출 방법의 차이점에 대해 설명하겠습니다. 도움이 되기를 바랍니다.

Java에서 이 메소드를 사용하는 방법 Java에서 이 메소드를 사용하는 방법 Apr 18, 2023 pm 01:58 PM

1. this 키워드 1. this 유형: 호출되는 개체는 해당 개체의 참조 유형입니다. 2. 사용법 요약 1. this.data;//Access 속성 2. this.func();//Access 메서드 3.this ( );//이 클래스의 다른 생성자를 호출합니다. 3. 사용법 설명 1.this.data가 멤버 메서드에 사용됩니다. 이것이 추가되지 않으면 어떻게 되는지 살펴보겠습니다. classMyDate{publicintyear;publicintmonth;publicintday; 월,월){예

JavaScript는 이 포인터를 어떻게 변경합니까? 세 가지 방법에 대한 간략한 분석 JavaScript는 이 포인터를 어떻게 변경합니까? 세 가지 방법에 대한 간략한 분석 Sep 19, 2022 am 09:57 AM

JavaScript는 이 포인터를 어떻게 변경합니까? 다음 기사에서는 JS에서 이 포인터를 변경하는 세 가지 방법을 소개합니다. 이것이 도움이 되기를 바랍니다.

JavaScript 화살표 함수에서 이에 대한 자세한 설명 JavaScript 화살표 함수에서 이에 대한 자세한 설명 Jan 25, 2024 pm 01:41 PM

JavaScript의 화살표 함수는 자체 this 키워드가 없는 비교적 새로운 구문입니다. 반대로 화살표 함수의 this는 이를 포함하는 범위 개체를 가리킵니다. 1. 화살표 함수의 This는 다음과 같습니다. 2. 화살표 함수는 생성자로 사용할 수 없습니다. 3. 화살표 함수는 메서드로 사용할 수 없습니다.

See all articles