apply call bind 它们是一个可以改变函数this指向的方法
// 以call为例
var name = 'window name'
function show_name(){
console.log(this.name)
}
show_name() // window name
var person = {
name: 'person name'
}
show_name.call(person) // person name
apply call bind 同时可以向函数内部传递参数
// 以call为例
var name = 'window name'
function show_info(age,sex){
console.log(this.name + ':' + 'age:' + age + 'sex:' + sex)
}
show_info(28,'男') // window name:age:28sex:男
var person = {
name: 'person name'
}
show_info.call(person,28,'男') // person name:age:28sex:男
三者的区别
- apply和call 都可以主动触发函数调用,bind具有返回值,需要手动触发
- call和bind的传参形式一样,apply是以数组的形式传参
// apply和call 都可以主动触发函数调用,bind需要手动触发
function show_info(age,sex){
console.log(this.name)
}
var person = {
name: 'person name'
}
show_info.call(person) // person name
show_info.bind(person) // 无效果
const fun = show_info.bind(person)
fun()
// call和bind的传参形式一样,apply是以数组的形式传参
function show_info(age,sex){
console.log(this.name + ':' + 'age:' + age + 'sex:' + sex)
}
var person = {
name: 'person name'
}
show_info.call(person,28,'男') // person name:age:28sex:男
const fun = show_info.bind(person,28,'男')
fun() // person name:age:28sex:男
show_info.apply(person,[28,'男']) // person name:age:28sex:男
注:es6中箭头函数不能用以上方法修改this指向
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。