`

javascript的call()与apply()

阅读更多

 

call方法: 

语法:call([thisObj[,arg1[, arg2[,   [,.argN]]]]]) 

定义:调用一个对象的一个方法,以另一个对象替换当前对象。 

说明: 

call 方法可以用来代替另一个对象调用一个方法。call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj 指定的新对象。 

如果没有提供 thisObj 参数,那么 Global 对象被用作 thisObj。 

 

apply方法: 

语法:apply([thisObj[,argArray]]) 

定义:应用某一对象的一个方法,用另一个对象替换当前对象。 

说明: 

如果 argArray 不是一个有效的数组或者不是 arguments 对象,那么将导致一个 TypeError。 

如果没有提供 argArray 和 thisObj 任何一个参数,那么 Global 对象将被用作 thisObj, 并且无法被传递任何参数。

 

 

两个方法其实只有参数不同。

 

/**定义一个animal类*/
function Animal(){
	this.name = "Animal";
	this.showName = function(){
		alert(this.name);
	}
}
/**定义一个Cat类*/
function Cat(){
	this.name = "Cat";
}

/**创建两个类对象*/
var animal = new Animal();
var cat = new Cat();

//通过call或apply方法,将原本属于Animal对象的showName()方法交给当前对象cat来使用了。
//输入结果为"Cat"
animal.showName.call(cat,",");
//animal.showName.apply(cat,[]);
   

 

分享到:
评论

相关推荐

    JavaScript中call与apply方法

    JavaScript中call与apply方法

    关于Javascript中call与apply的进一步探讨

    `apply`方法与`call`类似,主要区别在于传递参数的方式。`apply`接受两个参数:第一个参数同样是`this`值,第二个参数是一个数组或类数组对象,其中的元素作为函数的参数: ```javascript func.apply(thisArg, ...

    javascript callApply代码示例

    javascript callApply代码示例

    理解JavaScript的caller callee call apply

    ### 理解JavaScript中的`caller`, `callee`, `call`, `apply` #### Arguments对象:JavaScript函数调用的参数管理器 在JavaScript中,每个函数都有一个隐含参数`arguments`,它允许开发者访问传递给函数的所有参数...

    淡淡简单描述javascript中方法apply和call

    淡淡简单描述javascript中方法apply和call

    javascript中apply和call方法的作用及区别说明

    1、call,apply都属于Function.prototype的一个方法,它是JavaScript引擎内在实现的,因为属于Function.prototype,所以每个Function对象实例(就是每个方法)都有call,apply属性。既然作为方法的属性,那它们的使用...

    浅谈javascript中的call、apply、bind_.docx

    JavaScript 中的 call、apply、bind 方法详解 JavaScript 中的 call、apply、bind 方法是 Function 对象自带的三个方法,这三个方法的主要作用是转变函数中的 this 指向,从而可以达到“接花移木”的效果。下面将对...

    call与apply区别 详细解读.pdf

    call与apply区别详细解读 call和apply是JavaScript中的两个重要方法,它们都是Function.prototype中的方法,这意味着每个函数都可以使用这两个方法。它们的作用是改变函数体内的this对象的值,以扩充函数赖以运行的...

    js中call与apply的用法小结

    在JavaScript中,`call` 和 `apply` 是两种非常重要的函数调用方式,它们都用于改变函数执行时的上下文,即`this`的指向。本文将深入探讨这两种方法的用法及其在实际编程中的应用。 ### 1. `call` 的基本用法 `...

    Js的call与apply1

    JavaScript中的`call`和`apply`是两种非常关键的方法,它们允许我们改变函数内部`this`的指向,同时也为实现模拟继承提供了可能。虽然JavaScript不直接支持类继承,但通过`call`和`apply`,我们可以实现类似的效果。...

    javascript中call和apply方法浅谈

    在JavaScript中,`call`和`apply`是两种非常重要的函数调用方式,它们都用于改变函数内部`this`的指向,实现函数的动态绑定。这两个方法都是Function对象的原型方法,可以应用到任何函数上。 首先,让我们深入理解`...

    Javascript - 全面理解 caller,callee,call,apply (转载)

    `apply`与`call`相似,只是传递参数的方式不同: ```javascript sayHello.apply(obj, ['World']); // 输出 "Hello, World" ``` 在这两个示例中,`obj`作为`sayHello`函数的上下文,使得`this.name`能够正确地引用`...

    【JavaScript源代码】JavaScript函数之call、apply以及bind方法案例详解.docx

    - `apply()` 与`call()`类似,但传递参数的方式不同。`apply()`接受两个参数:第一个是设置的`this`值,第二个是参数数组或`arguments`对象。函数内部的参数会从这个数组或`arguments`对象中取出。 - 模拟实现`...

    javascript call和apply方法

    另一方面,`apply`方法与`call`非常相似,也是用于改变`this`的值,但它接受一个参数数组。这使得`apply`更适合于处理动态数量的参数。`apply`的基本语法如下: ```javascript functionName.apply(object, [arg1, ...

    JavaScript中的apply和call函数详解_.docx

    `apply`与`call`相似,但参数传递方式不同: ```javascript function.apply(thisArg, [argsArray]) ``` `apply`也接收`thisArg`作为第一个参数,但第二个参数`argsArray`必须是一个数组或类数组对象,它的所有元素会...

    Javascript中call,apply,bind方法的详解与总结

    本文针对JavaScript中三个重要的函数方法——call、apply和bind,进行详尽的分析,并在文章的结尾部分对这三个方法之间的联系和区别进行了概括,以便于读者更深入地理解它们的用途和应用场景。 首先,我们来探讨...

    跟我学习javascript的call(),apply(),bind()与回调

    本文将详细解释JavaScript中call(), apply(), 和 bind() 方法的作用、语法以及使用场景,并且会探讨回调函数的使用,帮助理解这些概念在实际编程中的应用。 首先,我们来探讨call() 和 apply() 方法。这两个方法都...

    开启Javascript中apply、call、bind的用法之旅模式

    2. apply与call的区别 apply和call在改变函数执行时的上下文(context)方面是相同的,它们的主要区别在于传参的方式。apply需要把参数放在一个数组里传递,而call则是接受一个参数列表。当参数数量未知时,通常使用...

    详解js中call与apply关键字的作用.docx

    JavaScript中的`call`和`apply`是两种非常重要的方法,它们都用于改变函数内部`this`的指向,并执行该函数。这两个方法都是Function对象的原型方法,因此所有的函数都具备`call`和`apply`。 1. `call`方法: - `...

    Javascript中call与apply的学习笔记

    ### JavaScript中call与apply方法的学习笔记 在JavaScript编程中,`call`和`apply`是两个非常重要的方法,它们都是`Function`原型上的方法,用于改变函数的`this`上下文(即函数体内`this`的指向)到指定的对象,并...

Global site tag (gtag.js) - Google Analytics