首页 > 移动平台 > 详细

call()、apply()、bind()

时间:2018-07-31 12:48:23      阅读:179      评论:0      收藏:0      [点我收藏+]

1、首先 每个Function对象里面都存在call()和apply()方法,及在函数的原型里面

技术分享图片

2、语法是
  function.apply(thisObj,[a,b,c])  

  function.call(thisObj,a,b,c)

3、共同点

都是 用来代替另一个对象调用一个方法,将一个函数的对象上下文重新改变为thisObj指定的新对象

4、不同点

apply()接受两个参数,将参数放进数组里面

call()接受多个参数,参数为一串列表

5、例子

function add(a,b){

return a+b;
}
function sub(a,b){
return a-b;
}

var a1 = add.apply(sub,[4,2])

var a2 = sub.apply(add,[4,2])

var a3 = add.call(sub,4,2)

console.log(a1,a2,a3)

6、实现继承

function Animal(name){
this.name = name;
this.showName = function(){
alert(this.name);
}
}

function Cat(name){
Animal.apply(this,[name]);
}

var cat = new Cat("咕咕");
cat.showName();

/*call的用法*/
Animal.call(this,name);

 

call()、apply()、bind()

原文:https://www.cnblogs.com/lk1186578324/p/9395010.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!