JavaScript函数this指向

函数的this指向,函数this的确定是在函数执行的时候确认的不是在函数定义的时候确认的

自由变量的查找,是在函数定义的地方查找,向上级作用域查找,不是在执行的地方查找。


image

第一个打印的this.count是1,第二个是一个坑,第二个打印的是undefined

image

这个打印结果是4个4

    let i
    for( i = 0 ; i<=3; i++) {
      setTimeout(function() {
        console.log(i)
      }, 0)
    }

setTimeout()里的函数是作为一个普通函数执行,this是window

image

箭头函数永远取它上一级作用域的this,也就是始终指向箭头函数申明时所在作用域下的this值。本身不会决定this的值

image

image

改变函数内this指向

call()、bind()、apply()

1.call

  • call的第一个作用是可以调用函数,第二个作用是可以改变函数的this的指向
  • call也可以实现继承

image

2.apply

  • 第一个作用也是调用函数,第二个作用也是改变函数的this指向
  • 但是他的参数必须是数组形式
  • 主要应用是结合Math

image

f.apply(第一个参数是this,第二个参数是数组)
输出是字符串模式

3.bind

  • 不会调用函数,可以改变函数this的指向
  • 返回的是原函数改变this指向后的新函数
  • 当我们有函数不需要立即调用,但是有需要改变this指向时用bind

image

image

4.call、apply、bind的异同点

image

posted @ 2021-04-06 14:22  嘿!那个姑娘  阅读(81)  评论(0编辑  收藏  举报