찾다
웹 프론트엔드JS 튜토리얼javascript_기초지식 중 call(), apply() 메소드 분석 예시

1. 방법 정의

통화 방법:
구문: call([thisObj[,arg1[, arg2[, [,.argN]]]]])
정의: 현재 객체를 다른 객체로 대체하기 위해 객체의 메소드를 호출합니다.
설명:
호출 메소드는 다른 객체를 대신하여 메소드를 호출하는 데 사용될 수 있습니다. call 메소드는 함수의 객체 컨텍스트를 초기 컨텍스트에서 thisObj가 지정한 새 객체로 변경합니다.
thisObj 매개변수가 제공되지 않으면 Global 개체가 thisObj로 사용됩니다.

신청방법 :
구문: apply([thisObj[,argArray]])
정의: 객체의 메소드를 적용하여 현재 객체를 다른 객체로 대체합니다.
설명:
argArray가 유효한 배열이 아니거나 인수 객체가 아닌 경우 TypeError가 발생합니다.
argArray나 thisObj가 모두 제공되지 않으면 전역 개체가 thisObj로 사용되며 매개 변수를 전달할 수 없습니다.

2. 일반적인 예

아、

코드 복사 코드는 다음과 같습니다.

함수 추가(a,b)
{
경고(a b);
}
함수 하위(a,b)
{
경고(a-b);
}

add.call(sub,3,1)

이 예의 의미는 sub를 add, add.call(sub,3,1) == add(3,1)로 바꾸는 것입니다. 따라서 실행 결과는 다음과 같습니다. Alert(4) // 참고: js에서 함수는 실제로 객체이고, 함수 이름은 Function 객체에 대한 참조입니다.

ㄴ、

코드 복사 코드는 다음과 같습니다.

함수 동물(){
This.name = "동물"
This.showName = function(){
경고(이.이름)
}  
}
함수 Cat(){
This.name = "고양이"
}
var 동물 = 새로운 동물()
var 고양이 = 새로운 고양이()
//call이나 apply 메소드를 통해 원래 Animal 객체에 속한 showName() 메소드를 cat 객체에 넘겨서 사용하게 됩니다.
//입력 결과는 "Cat"입니다
동물.showName.call(고양이,",")
//animal.showName.apply(cat,[]);

호출은 원래 cat에 동물의 메소드를 넣어서 실행한다는 의미입니다.

c. 상속 구현

코드 복사 코드는 다음과 같습니다.
함수 동물(이름){
This.name = 이름
This.showName = function(){
경고(이.이름)
}  

함수 Cat(이름){
Animal.call(이, 이름)

var cat = new Cat("검은 고양이")
cat.showName();

Animal.call(this)은 이 객체 대신 Animal 객체를 사용한다는 의미입니다. 그러면 Cat은 Animal의 모든 속성과 메소드를 가지고 있지 않습니까? Cat 객체는 Animal의 메소드와 속성을 직접 호출할 수 있습니다.

d. 다중 상속

코드 복사 코드는 다음과 같습니다.
함수 Class10()
{
This.showSub = 함수(a,b)
{
경고(a-b);
}
}
함수 Class11()
{
This.showAdd = 함수(a,b)
{
경고(a b);
}
}
함수 Class2()
{
Class10.call(this);
Class11.call(this);
}

매우 간단합니다. 다중 상속을 달성하려면 두 번의 호출을 사용하세요
물론 프로토타입 체인을 사용하는 등 js를 상속하는 다른 방법도 있습니다. 이는 이 기사의 범위에 포함되지 않습니다. 여기서는 호출 사용법만 설명합니다. 호출과 적용에 관해 말하면 이 두 메서드는 기본적으로 동일한 의미입니다. 차이점은 호출의 두 번째 매개 변수는 모든 유형이 될 수 있지만 적용의 ​​두 번째 매개 변수는 배열이거나 인수일 수 있다는 것입니다. 🎜> 그리고 수신자, 발신자..

요약:

간단히 말하면 같은 점: 두 가지 방법의 효과는 완전히 동일합니다

차이: 메소드에 전달된 매개변수가 다릅니다

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
es6数组怎么去掉重复并且重新排序es6数组怎么去掉重复并且重新排序May 05, 2022 pm 07:08 PM

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

JavaScript的Symbol类型、隐藏属性及全局注册表详解JavaScript的Symbol类型、隐藏属性及全局注册表详解Jun 02, 2022 am 11:50 AM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

原来利用纯CSS也能实现文字轮播与图片轮播!原来利用纯CSS也能实现文字轮播与图片轮播!Jun 10, 2022 pm 01:00 PM

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

JavaScript对象的构造函数和new操作符(实例详解)JavaScript对象的构造函数和new操作符(实例详解)May 10, 2022 pm 06:16 PM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

javascript怎么移除元素点击事件javascript怎么移除元素点击事件Apr 11, 2022 pm 04:51 PM

方法:1、利用“点击元素对象.unbind("click");”方法,该方法可以移除被选元素的事件处理程序;2、利用“点击元素对象.off("click");”方法,该方法可以移除通过on()方法添加的事件处理程序。

JavaScript面向对象详细解析之属性描述符JavaScript面向对象详细解析之属性描述符May 27, 2022 pm 05:29 PM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

foreach是es6里的吗foreach是es6里的吗May 05, 2022 pm 05:59 PM

foreach不是es6的方法。foreach是es3中一个遍历数组的方法,可以调用数组的每个元素,并将元素传给回调函数进行处理,语法“array.forEach(function(当前元素,索引,数组){...})”;该方法不处理空数组。

整理总结JavaScript常见的BOM操作整理总结JavaScript常见的BOM操作Jun 01, 2022 am 11:43 AM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于BOM操作的相关问题,包括了window对象的常见事件、JavaScript执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。

See all articles

핫 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를 무료로 생성하십시오.

뜨거운 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.