call Apply bind详解
call方法:

语法:call(thisObj,'',''........) 定义:调用一个对象的一个方法,以另一个对象替换当前对象 说明:call方法可以用来代替另一个对象调用一个方法。call方法可将一个函数的对象上下文初始的上下文改变为由thisObj指定的新对象,如果没有提供thisObj参数,那么global对象被用做thisObj

apply方法:

语法:apply(thisObj,['','',''....]) 定义:应用某一个对象的方法,用另一个对象替换当前对象 如果argArray不是一个有效的数组或者不是arguments对象,那么将导致一个TypeError.如果没有提供argArray和thisObj任何一个参数,那么Global对象将用做thisObj,并且无法被传递任何参数

相同之处:

1、都是用来改变函数的this对象的指向
2、第一个参数都是this要指向的对象
3、都可以利用后续参数传参 不同之处:
1、call和apply都是对函数的直接调用,而bind方法返回的仍然是一个函数,因此后面需要加上()来进行调用才可以

案例一:bind与call、apply的区别

var a={
     name:'阿姨请别把您闺女介绍给我',
     sex:'男',
     age:'24',
     say:function(){
          console.log(this.name+',今年'+this.age+'岁,性别'+this.sex)
     }
}
var b={
     name:'就要把闺女介绍给你',
     sex:'女',
     age:'18'
}
a.say();//阿姨请别把您闺女介绍给我,今年24岁了,性别男
那么我们想一下如何让b用say的方法显示数据呢?
用call方法:a.say.call(b)
用apply方法:a.say.apply(b)
用bind方法:a.say.bind(b)()

案例二:call与apply的区别

var a={
     name:'阿姨请不要把您闺女介绍给我',
     sex:'男',
     age:'18',
     say:function(school,grade){
          console.log(this.name+'性别'+this.sex+'年龄'+this.age+school+grade)
     }
}
var b={
     name:'就喜欢把闺女介绍给你',
     sex:'女',
     age:'18'
}
现在我们看say方法中多了两个参数,我们通过call和apply的参数进行传参
用call方法:a.say.call(b,'清华','三年级')
用apply方法:a.say.apply(b,['清华','六年级'])
call后面的参数与say方法中是一一对应的,而apply第二个参数是一个数组
用bind方法:a.say.bind(b,'清华','三年级')
但是由于bind返回的仍然是一个函数,所以我们可以在调用的时候在进行传参
a.say.bind(b)('清华','三年级')


if(!Function.prototype.bind){
     Function.prototype.bind=function(obj){
          var This=this;
          var args=arguments;
          return function(){
               This.apply(obj,Array.prototype.slice.call(args,1))
          }
     }
}
call Apply bind详解的更多相关文章
- 011-Scala中的apply实战详解
		011-Scala中的apply实战详解 object中的apply方法 class中的apply方法 使用方法 apply方法可以应用在类或者Object对象中 class类 必须要创建实例化的类对 ... 
- Js apply 方法 详解
		Js apply方法详解 我在一开始看到JavaScript的函数apply和call时,非常的模糊,看也看不懂,最近在网上看到一些文章对apply方法和call的一些示例,总算是看的有点眉目了,在这 ... 
- Js apply()使用详解
		Js apply方法详解 我在一开始看到javascript的函数apply和call时,非常的模糊,看也看不懂,最近在网上看到一些文章对apply方法和call的一些示例,总算是看的有点眉目了,在这 ... 
- angularJS中$apply()方法详解
		这篇文章主要介绍了angularJS中$apply()方法详解,需要的朋友可以参考下 对于一个在前端属于纯新手的我来说,Javascript都还是一知半解,要想直接上手angular JS,遇到的 ... 
- Js apply方法详解,及其apply()方法的妙用
		Js apply方法详解 我在一开始看到javascript的函数apply和call时,非常的模糊,看也看不懂,最近在网上看到一些文章对apply方法和call的一些示例,总算是看的有点眉目了,在这 ... 
- 原生JS:Function对象(apply、call、bind)详解
		Function对象(apply.call.bind) 原创文章,转摘请注明出处:苏福:http://www.cnblogs.com/susufufu/p/5850180.html 本文参考MDN做的 ... 
- javascript中的apply,call,bind详解
		apply.call 在 javascript 中,call 和 apply 都是为了改变某个函数运行时的上下文(context)而存在的,换句话说,就是为了改变函数体内部 this 的指向. Jav ... 
- call,apply和bind详解
		一.call和apply call和apply其实是同一个东西,区别只有参数不同,call是apply的语法糖,所以就放在一起说了,这两个方法都是定义在函数对象的原型上的(Function.proto ... 
- call,apply,bind详解
		为什么要改变this指向? 我们知道bind,call,apply的作用都是用来改变this指向的,那为什么要改变this指向呢?请看下面的例子: var name="lucy"; ... 
随机推荐
- Map.putAll方法
			import Java.util.HashMap; public class Map_putAllTest { public static void main(String[] args){ / ... 
- python 往mysql数据库中插入多条记录。
			最近想写mysql库,用到insert into语句,如何一次性将多条记录插入库表中呢. MySQLdb提供了两个执行语句的方法:一个是execute(),另一个是executemany() exec ... 
- photoKit使用笔记
			@主要用到的类 1PHAssetCollection:图片资源数组(代表着相簿数组) 作用:获取相簿资源数组 示例代码: //获取相簿资源 PHFetchResult<PHAssetCollec ... 
- Genymotion模拟器无法直接安装APP
			使用Genymotion模拟器安装APP的过程中,将我们的apk拖进去模拟器报以下错误: Genymotion官网常见问题解决办法汇集地址:https://www.genymotion.com/#!/ ... 
- mysql Access denied for user root @localhost (using password:YES)错误
			C:\AppServ\MySQL> mysql -u root -p Enter password: ERROR 1045 (28000): Access denied for user 'r ... 
- 常见排序算法JAVA实现
			1.冒泡排序,时间复杂度:最好:T(n) = O(n) ,情况:T(n) = O(n2) ,平均:T(n) = O(n2) public int[] bubbleSort(int[] nums) { ... 
- 跟随我在oracle学习php(18)
			修改表: 一般概述 通常,创建一个表,能搞定(做到)的事情,修改表也能做到.大体来说,就可以做到: 增删改字段: 增:alter table 表名 add [column] 字段名 字段类 ... 
- week7
			catalog 1.面向对象 2.类的继承(续):直接继承与间接继承 3.类方法.静态方法.属性方法 4.getitem 5.反射 6._new_\_metaclass_ 7.异常处理 1.面向对象 ... 
- 共识机制:AngelToken技术的根基
			共识机制是区块链技术的一个核心问题,它决定了区块链中区块的生成法则,保证了各节点的诚实性.账本的容错性和系统的稳健性. 常用的共识机制主要有 PoW.PoS.DPoS.Paxos.PBFT等. 基于区 ... 
- spring(AOP)静态代理
			姓名:黄于霞 班级:软件151 1.定义抽象主题接口,假设需实现一个计算的类Math.完成加.减.乘.除功能,如下所示: 2.主题类,算术类,实现抽象接口. 3.代理类 4.测试运行 5.总 ... 
