목차
javascript에서 call과 apply의 차이점은 무엇인가요?
웹 프론트엔드 프런트엔드 Q&A javascript에서 호출과 적용의 차이점은 무엇입니까

javascript에서 호출과 적용의 차이점은 무엇입니까

Jan 28, 2022 pm 03:24 PM
html javascript 프런트 엔드

JavaScript에서는 call() 메서드와 apply() 메서드가 동일한 기능을 가지고 있지만 call() 메서드를 사용할 때 함수에 전달되는 매개변수는 하나씩 나열되어야 합니다. 하나. apply() 를 사용할 때 함수에 전달되는 것은 매개변수 배열입니다.

javascript에서 호출과 적용의 차이점은 무엇입니까

이 튜토리얼의 운영 환경: Windows 10 시스템, JavaScript 버전 1.8.5, Dell G3 컴퓨터.

javascript에서 call과 apply의 차이점은 무엇인가요?

call() 메소드는 지정된 이 값과 별도로 제공되는 매개변수(매개변수 목록)를 사용하여 함수를 호출합니다.

참고: 이 메소드의 기능은 apply() 메소드와 유사합니다. 유일한 차이점은 call() 메소드는 여러 매개변수 목록을 허용하는 반면, apply() 메소드는 여러 매개변수를 포함하는 배열을 허용한다는 것입니다.

 Syntax

fun.call(thisObj[, arg1[, arg2[, ...]]])
로그인 후 복사

  정의: 현재 개체를 다른 개체로 대체하려면 개체의 메서드를 호출합니다.

  설명:

   호출 메서드는 다른 개체 대신 메서드를 호출하는 데 사용할 수 있습니다. call 메소드는 함수의 객체 컨텍스트를 초기 컨텍스트에서 thisObj가 지정한 새 객체로 변경합니다.

   thisObj 매개변수가 제공되지 않으면 전역 개체가 thisObj로 사용됩니다.

 Parameter

  thisObj

  fun 함수가 실행될 때 지정하는 값입니다. 함수가 실행될 때 지정된 this 값이 반드시 실제 this 값일 필요는 없습니다. 함수가 엄격하지 않은 모드에 있는 경우 null 및 undef로 지정된 this 값은 자동으로 전역 개체를 가리킵니다(브라우저는 창 개체), 값이 기본 값(숫자, 문자열, 부울 값)인 this는 기본 값의 자동 래핑 개체를 가리킵니다.

  arg1, arg2, ...

   지정된 매개변수 목록입니다.

반환 값

반환 결과에는 지정된 this 값과 매개변수가 포함됩니다.

apply()

apply() 메서드는 지정된 this 값과 배열(또는 배열 유사 객체)로 제공되는 인수를 사용하여 함수를 호출합니다.

Syntax

fun.apply(thisObj, [argsArray])
로그인 후 복사

 정의: 현재 개체를 다른 개체로 바꾸는 개체의 메서드를 적용합니다.

 참고:

  argsArray가 유효한 배열이 아니거나 인수 개체가 아닌 경우 TypeError가 발생합니다.

   argArray나 thisObj가 모두 제공되지 않으면 전역 개체가 thisObj로 사용되며 매개 변수를 전달할 수 없습니다.

Parameter

 thisObj

  fun 함수가 실행될 때 지정하는 값입니다. 함수가 실행될 때 지정된 this 값이 반드시 실제 this 값일 필요는 없습니다. 함수가 엄격하지 않은 모드에 있는 경우 지정된 값이 null이거나 정의되지 않으면 자동으로 전역 객체를 가리킵니다. (브라우저에서는 창 개체입니다.) 값이 기본 값(숫자, 문자열, 부울 값)인 이 개체는 기본 값의 자동 래핑 개체를 가리킵니다.

  argsArray

   배열 또는 배열 유사 객체로, 배열 요소는 별도의 매개변수로 fun 함수에 전달됩니다. 이 매개변수의 값이 null이거나 정의되지 않은 경우 매개변수를 전달할 필요가 없음을 의미합니다. ECMAScript 5

  부터 배열과 유사한 객체를 사용할 수 있습니다.

요약

둘 다 동일한 기능을 갖고 있으며 둘 다 obj(즉, this)를 thisObj에 바인딩합니다. 이때 thisObj는 obj의 속성과 메서드를 갖습니다. 즉, thisObj는 obj의 속성과 메서드를 "상속"합니다. 유일한 차이점은 apply는 배열 매개변수를 허용하는 반면 call은 연속 매개변수를 허용한다는 것입니다.

call() 메소드와 apply() 메소드는 동일한 기능을 가지고 있지만 차이점은 매개변수를 받는 방식에 있습니다. call()의 경우 첫 번째 매개변수는 변경되지 않는 this 값입니다. 변경되는 점은 나머지 매개변수가 함수에 직접 전달된다는 것입니다. (call() 메소드를 사용할 경우 함수에 전달되는 매개변수가 하나씩 나열되어야 합니다. apply()를 사용할 경우 매개변수 배열이 함수에 전달됩니다.) 다음 코드는 설명합니다.

function add(c, d){
    return this.a + this.b + c + d;
}
var o = {a:1, b:3};
add.call(o, 5, 7); // 1 + 3 + 5 + 7 = 16
add.apply(o, [10, 20]); // 1 + 3 + 10 + 20 = 34 
로그인 후 복사

call과 Apply 모두 다음과 같습니다. 무언가를 변경하는 데 사용됩니다. 함수가 실행될 때 컨텍스트는 즉, 함수 본문 내부에서 this의 포인터를 변경하는 것입니다. JavaScript 함수에는 "정의 컨텍스트"와 "런타임 컨텍스트" 및 "컨텍스트가 변경될 수 있다"라는 개념이 있기 때문입니다.

두 기능은 완전히 동일하지만 매개변수를 받아들이는 방식이 다릅니다. 예를 들어 다음과 같이 정의된 fun 함수가 있습니다.

var fun = function(arg1, arg2) {};
로그인 후 복사

는 fun.call(this, arg1, arg2); 또는 fun.apply(this, [arg1, arg2]);를 통해 호출할 수 있습니다. 그 중에서 지정하려는 컨텍스트는 임의의 JavaScript 객체일 수 있습니다(JavaScript의 모든 것은 객체입니다). 호출은 매개변수를 순서대로 전달해야 하며 Apply는 매개변수를 배열에 넣습니다.

자바스크립트에서는 함수의 매개변수 갯수가 정해져 있지 않기 때문에 적용 조건에 따라 매개변수가 숫자를 확실히 알면 call을 사용하고, 확실하지 않을 때는 적용을 사용하여 매개변수를 푸시하면 됩니다. 배열을 전달하세요. 매개변수 개수가 불확실한 경우 인수 배열을 통해 함수 내에서 모든 매개변수를 탐색할 수 있습니다.

관련 권장 사항: javascript 학습 튜토리얼

위 내용은 javascript에서 호출과 적용의 차이점은 무엇입니까의 상세 내용입니다. 자세한 내용은 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 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

HTML의 테이블 테두리 HTML의 테이블 테두리 Sep 04, 2024 pm 04:49 PM

HTML의 테이블 테두리 안내. 여기에서는 HTML의 테이블 테두리 예제를 사용하여 테이블 테두리를 정의하는 여러 가지 방법을 논의합니다.

HTML 여백-왼쪽 HTML 여백-왼쪽 Sep 04, 2024 pm 04:48 PM

HTML 여백-왼쪽 안내. 여기에서는 HTML margin-left에 대한 간략한 개요와 코드 구현과 함께 예제를 논의합니다.

HTML의 중첩 테이블 HTML의 중첩 테이블 Sep 04, 2024 pm 04:49 PM

HTML의 Nested Table에 대한 안내입니다. 여기에서는 각 예와 함께 테이블 내에 테이블을 만드는 방법을 설명합니다.

HTML 테이블 레이아웃 HTML 테이블 레이아웃 Sep 04, 2024 pm 04:54 PM

HTML 테이블 레이아웃 안내. 여기에서는 HTML 테이블 레이아웃의 값에 대해 예제 및 출력 n 세부 사항과 함께 논의합니다.

HTML 입력 자리 표시자 HTML 입력 자리 표시자 Sep 04, 2024 pm 04:54 PM

HTML 입력 자리 표시자 안내. 여기서는 코드 및 출력과 함께 HTML 입력 자리 표시자의 예를 논의합니다.

HTML 정렬 목록 HTML 정렬 목록 Sep 04, 2024 pm 04:43 PM

HTML 순서 목록에 대한 안내입니다. 여기서는 HTML Ordered 목록 및 유형에 대한 소개와 각각의 예에 대해서도 설명합니다.

HTML에서 텍스트 이동 HTML에서 텍스트 이동 Sep 04, 2024 pm 04:45 PM

HTML에서 텍스트 이동 안내. 여기서는 Marquee 태그가 구문과 함께 작동하는 방식과 구현할 예제에 대해 소개합니다.

HTML 온클릭 버튼 HTML 온클릭 버튼 Sep 04, 2024 pm 04:49 PM

HTML onclick 버튼에 대한 안내입니다. 여기에서는 각각의 소개, 작업, 예제 및 다양한 이벤트의 onclick 이벤트에 대해 설명합니다.

See all articles