call、apply、bind方法详解
2019-06-07 21:43
1506 查看
在 javascript 中,call 和 apply 都是为了改变某个函数运行时的上下文(context)而存在的,换句话说,就是为了改变函数体内部 this 的指向。
bind()最简单的用法是创建一个函数,使这个函数不论怎么调用都有同样的this值。常见的错误就像上面的例子一样,将方法从对象中拿出来,然后调用,并且希望this指向原来的对象。
对于 apply、call 二者而言,作用完全一样,只是接受参数的方式不太一样。便于记忆,单词字母多的为参数难写的,既数组的形式,反之为普通的带逗号方式
特别注意:每个函数执行都会隐式带了一个call/apply 比如:
foo(1,2)==foo.call(null,1,2)==foo.call(null,[1,2])
相关文章推荐
- Javascript中apply()、call()和bind()方法详解
- JavaScript方法call,apply,caller,callee,bind的使用详解及区别
- JavaScript方法call,apply,caller,callee,bind的使用详解及区别
- call, apply, bind方法详解
- JS中的call、apply、bind方法详解
- Javascript中call,apply,bind方法的详解与总结
- Javascript中call,apply,bind方法的详解与总结
- JavaScript方法call,apply,caller,callee,bind的使用详解及区别
- JavaScript方法call,apply,caller,callee,bind的使用详解及区别
- JavaScript方法call,apply,caller,callee,bind的使用详解及区别
- JavaScript方法call,apply,caller,callee,bind的使用详解及区别
- Javascript中call,apply,bind方法的详解与总结
- JavaScript方法call,apply,caller,callee,bind的使用详解及区别
- Javascript中call,apply,bind方法的详解与总结
- Javascript中call,apply,bind方法的详解与总结
- JS中的call、apply、bind方法详解
- JavaScript方法call,apply,caller,callee,bind的使用详解及区别
- call、apply、bind方法详解
- Javascript中call,apply,bind方法的详解与总结
- js中bind、call、apply方法详解