bind、call、apply区别?如何实现一个bind?
时间: 2024-01-27 20:03:54 浏览: 152
Javascript中call,apply,bind方法的详解与总结
5星 · 资源好评率100%
bind、call、apply都是用来改变函数执行时的上下文(this指向)的方法。
- `call`和`apply`作用相似,都是立即执行函数,并且可以传递参数,不同的是`call`接收的是参数列表,而`apply`接收的是参数数组。
- `bind`方法与`call`和`apply`不同的是,它不会立即执行函数,而是返回一个新函数,这个新函数可以在稍后被调用,且可以传递参数。同时,`bind`方法返回的函数中的this指向绑定的对象。
下面是一个模拟实现`bind`的代码:
```javascript
Function.prototype.bind = function(context) {
var self = this;
var args = Array.prototype.slice.call(arguments, 1);
return function() {
var bindArgs = Array.prototype.slice.call(arguments);
return self.apply(context, args.concat(bindArgs));
}
}
```
该代码将`bind`方法添加到`Function.prototype`上,函数在调用`bind`时传入一个`context`参数,表示绑定的上下文(即函数执行时的`this`指向),然后返回一个新函数,新函数中的`this`指向绑定的`context`,并将传入`bind`方法的参数和新函数调用时传入的参数合并后作为参数传递给原函数。
阅读全文