javascript中的每一个Function对象都有一个apply()和一个call()方法,它们的语法分别是:

/*apply()方法*/

function.apply(thisObj[, argArray])

apply: 调用一个对象的一个方法,用另一个对象替换当前对象。 例如: B.apply(A,arguments); 即A对象应用B对象的方法。

/*call()方法*/

function.call(thisObj[, arg1[, arg2[, [,...argN]]]]);

call: 调用一个对象的一个方法,用另一个对象替换当前对象。 例如:B.call(A,args1,args2);即A对象调用B对象的方法。

相同点:

1.方法的含义是一样的,功能自然也是一样的;

2.第一个参数的作用是一样的。

不同点:两者传入的列表形式不一样

1.call可以传入多个参数

2.apply只能传入两个参数,所以器第二个参数往往是作为数组的形式传入。

意义:

实现(多重)继承

实例代码:

function sum(num1,num2){

return num1+num2

}

function sub(num1,num2){

return num1-num2

}

var a1 = sum.apply(sub,[4,2])  // sub调用sum内的方法

console.log(a1) // 6

var a2 = sub.apply(sum,[4,2])  // sum调用sub内部的方法

console.log(a2) // 2

var c1 = sum.call(sub,4,2)      // sub调用sum的方法

console.log(c1) // 6

var c2 = sub.call(sum,4,2)  // sum调用sub内部的方法

console.log(c2) // 2

window.color = 'red';

var o = {color:'blue'}

function sayColor(){

console.log(this)

console.log(this.color)

}

console.log(this) // window

sayColor.call(this)    // window    red

sayColor.call(window)   // window    red

sayColor.call(o)        // {color:'blue'}  blue

sayColor.apply(this) // window red

sayColor.apply(window) // window    red

sayColor.apply(o)        // {color:'blue'}  blue

实现继承

function Animal(name){

this.name = name

this.showName = function(){

console.log(this.name)

}

}

function Cat(name){

Animal.apply(this,[name])

}

var cat = new Cat("猫")

cat.showName() //猫

// 多继承

function Sum(){

this.sumadd = function(a,b){

console.log(a+b)

}

}

function Sub(){

this.subadd = function(a,b){

console.log(a-b)

}

}

function Js(){

console.log(this)            //Js {}

Sum.apply(this)

Sub.apply(this)

}

var a = new Js();

a.sumadd(3,1) //4

a.subadd(3,1) //2

/*bind()方法*/

bind() 这个方法会创建一个函数实例,其this值会被绑定到传给bind()函数的值

var objSayColor = sayColor.bind(o) //{color:'blue'}

objSayColor() // blue

var a = {

user: 'skl',

}

var b = function(e,d,f){

console.log(this.user)  //skl

console.log(e,d,f)  //10,1,2

};

var c = b.bind(a,10)

c(1,2)

总结:call和apply都是改变上下文中的this并立即执行这个函数,bind方法可以让对应的函数想什么时候调就什么时候调用,并且可以将参数在执行的时候添加,这是它们的区别,根据自己的实际情况来选择使用。

call(),apply()和bind()的区别的更多相关文章

  1. JS 中的this指向问题和call、apply、bind的区别

    this的指向问题 一般情况下this对象指向调用函数的对象,全局环境中执行函数this对象指向window. function a(){ console.log(this); //输出函数a中的th ...

  2. this+call、apply、bind的区别与使用

    http://www.ruanyifeng.com/blog/2018/06/javascript-this.html https://segmentfault.com/a/1190000018017 ...

  3. 改变this指针的apply,call,bind的区别

    apply.call 在 javascript 中,call 和 apply 都是为了改变某个函数运行时的上下文(context)而存在的,换句话说,就是为了改变函数体内部 this 的指向. Jav ...

  4. js中call、apply和bind的区别

    在JS中,这三者都是用来改变函数的this对象的指向的,他们有什么样的区别呢.在说区别之前还是先总结一下三者的相似之处:1.都是用来改变函数的this对象的指向的.2.第一个参数都是this要指向的对 ...

  5. call和apply和bind的区别

    在 javascript 中,call 和 apply 都是为了改变某个函数运行时的上下文(context)而存在的,换句话说,就是为了改变函数体内部 this 的指向. JavaScript 的一大 ...

  6. 有关call和apply、bind的区别及this指向问题

    call和apply都是解决this指向问题的方法,唯一的区别是apply传入的参数除了其指定的this对象之外的参数是一个数组,数组中的值会作为参数按照顺序传入到this指定的对象中. bind是解 ...

  7. Javascript中call,apply,bind的区别

    一.探索call方法原理 Function.prototype.call = function(obj) { // 1.让fn中的this指向obj // eval(this.toString().r ...

  8. JS中call()和apply()以及bind()的区别

    一.方法定义: apply:调用一个对象的一个方法,用另一个对象替换当前对象.例如:B.apply(A, arguments);即A对象应用B对象的方法. call:调用一个对象的一个方法,用另一个对 ...

  9. 超容易理解的call()、apply()、bind()的区别

    call().apply().bind()是用来改变this的指向的. 一 举个例子 一个叫喵喵的猫喜欢吃鱼,一个叫汪汪的小狗喜欢啃骨头,用代码实现如下: 有一天,小狗汪汪和喵喵共进午餐的时候,汪汪说 ...

  10. apply,all,bind的区别

    这三个都是用来改变this指向的 call() 和apply()的第一个参数相同,就是指定的对象.这个对象就是该函数的执行上下文.call()和apply()的区别就在于,两者接收的参数不一样.cal ...

随机推荐

  1. 【BZOJ4030】[HEOI2015]小L的白日梦

    [BZOJ4030][HEOI2015]小L的白日梦 题面 BZOJ 洛谷 题解 要求的是最小的不开心连续段的期望. 然后发现自己就不会做了. 然后就可以来抄题解啦. 首先来猜性质: 第一个,一定是按 ...

  2. react 生命周期函数介绍

    constructor():构造函数 执行:组件加载钱最先调用一次,仅调用一次. 作用:定义状态机变量. 注意:第一个语句必须为super(), 否则会报错:'this' is not allowed ...

  3. Hackers' Crackdown UVA - 11825 (状压dp)

    给出n个电脑,每个电脑连着n个服务,然后每个电脑都连着m个邻电脑,如果当前的电脑某个服务被断开了,相邻的电脑的服务也会被断开,每个电脑都只能操作一次,问你最多可以让多少种服务被断开.一种服务被断开的条 ...

  4. 洛谷P5289 [十二省联考2019]皮配(01背包)

    啊啊啊边界判错了搞死我了QAQ 这题是一个想起来很休闲写起来很恶心的背包 对于\(k=0\)的情况,可以发现选阵营和选派系是独立的,对选城市选阵营和学校选派系分别跑一遍01背包就行了 对于\(k> ...

  5. ASP.NET MVC 企业级实战

    1.泛型 public class List<T>{ } 当定义泛型类的实例时,必须指定这个实例所存储的实际类型,泛型允许程序员将一个实际的数据类型规约延迟至泛型的实例被创建时才确定,泛型 ...

  6. JavaEESpringMVC基础整理

    1.什么是 SpringMVC ? 在介绍什么是 SpringMVC 之前,我们先看看 Spring 的基本架构.如下图: 我们可以看到,在 Spring 的基本架构中,红色圈起来的 Spring W ...

  7. [译]asp-net-core-mvc-ajax-form-requests-using-jquery-unobtrusive

    原文 全文源码 开始项目 项目使用了package.json'文件,添加需要的前端package到项目中.在这我们添加了jquery-ajax-unobstrusive`. { "versi ...

  8. 自制stm32板子无法烧录程序的问题

    自己画的stm32板子一开始出现了无法烧录程序的情况,主要表现为在点击load图标后出现了Stlink connect error!Target dll has been concelled的窗口.在 ...

  9. js关于“变量提升、作用域、私有作用域等知识点”高级解题思路

    var i = 2,    x = 5;var fn = function (x) {    x += 3;    return function (y) {        console.log(( ...

  10. Linux 文本去重 之 命令sort 与 uniq

    sort [-fbMnrtuk] [file or stdin] 选项与参数: -f :忽略大小写的差异,例如 A 与 a 视为编码相同: -b :忽略最前面的空格符部分: -M :以月份的名字来排序 ...