简明了解apply()和call()

apply()和call()都是ES6语法的,而且都是函数的方法。数组

function foo() {
    alert(this.name)
}
var obj = {
    name: '小明'
}
foo() // undefine

这里this指向的是window。app

function foo() {
    alert(this.name)
}
var obj = {
    name: '小明',
    fn: foo
}
obj.fn() // 小明

这里this指向的是obj。函数

可是如今我不想改变obj的数据,我要怎么实现呢?this

function foo() {
    alert(this.name)
}
var obj = {
    name: '小明'
}
foo.apply(obj) //小明
foo.call(obj) //小明

上面就是利用了apply()或者call()。spa

那实际开发中,有哪些地方用到呢?code

好比如今咱们要获取数组中的最小值。blog

使用Math.max()这个方法,可是它接收的参数是数组以逗号分隔开的形式的。开发

alert(Math.max(1,2,3)) // 3

很明显,上面这种应该不是咱们想要的结果,这时候,就可使用咱们的apply()了。io

var arr = [1, 3, 2]
alert(Math.max.apply(window, arr)) // 3
相关文章
相关标签/搜索