改变函数内部的this指向: call apply bind

1.call方法可以调用函数 还可以改变函数内部的this指向,主要作用是可以实现继承:

fn.call(thisObj, arg1, arg2 ...)

2.apply方法可以调用函数 还可以改变函数内部的this指向,但是他的参数必须是数组[伪数组] :

fn.apply(thisObj, [arg1, arg2 ...])

apply方法可以借助于数学内置对象求数组中的最大值或最小值:

var arr = [1, 2, 33]
var max = Math.max.apply(Math, arr) // Math.min.apply()

3.bind方法不会调用函数,但是能够改变函数内部的this指向

如果有的函数我们不需要立即调用,但是又想改变这个函数内部的this指向[如改变定时器内部的this指向] 此时可以使用bind

例:有一个按钮,当点击后就禁用这个按钮 并在3秒钟后开启这个按钮

var btn = document.querySelector('button')
btn.onclick = function () {
	this.disabled = true
	setTimeout(function () { // 定时器中的this 指向的是window
		this.disabled = false // 此时的定时器中的this指向的是btn
	}.bind(this), 3000)
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值