这里是修真院前端小课堂,每篇分享文从

【背景介绍】【知识剖析】【常见问题】【解决方案】【编码实战】【扩展思考】【更多讨论】【参考文献】

八个方面深度解析前端知识/技能,本篇分享的是:

【简述JS中this的指向    】

 

1、背景介绍
    我们在写代码时候往往希望一个函数在不同环境下行为风格一致但是具体表现不一样,这个时候就需要this出场了。

    this是javascript的一个关键字,是函数内部的一个特殊对象(或this引用);this在不同的上下文执行环境中指代不同的对象,所以我们可以用同样的this代码输出不同的结果,从而简化代码。

1.1 THIS的特性

       会根据代码上下文语境自动改变其引用对象

this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象。

2.知识剖析
2.1 作为普通函数在全局环境中被调用

       先上代码:

clipboard.png

全局环境中的普通对象

        这里调用了a函数,而a函数的执行环境是全局环境,这里的this也就指向了全局变量window。

        在全局环境里面,this 永远指向 window,因此在全局环境里作为普通函数被调用的时候,this 也是指向 window。

2.2 作为对象的属性被调用

先来个总结:如果函数作为一个对象的属性方法,并且被调用的时候,那么这个属性方法中的this 就指向这个对象,来看代码:

clipboard.png

clipboard.png

clipboard.png
.png](/img/bVbmXa0)

![图片上传中...]

clipboard.png

但是当在在对象方法中再定义函数,这时候 this 又是 window

2.3 作为构造函数被调用

clipboard.png

clipboard.png

作为构造函数被调用的时候,this 代表它即将 new 出来的对象;如果不加 new,表示即作为普通函数调用,指向 window。

2.4作为 call/apply/bind 方法的调用

作为 call/apply/bind 方法被调用的时候指向传入的值。

2.5  其他:setTimeout、setInterval中的this;构造函数 prototype 属性; Eval函数;箭头函数.。

3.常见问题

    1、this 遇到return怎么办呢?什么意思呢,来看

clipboard.png

clipboard.png

clipboard.png

clipboard.png

        什么意思呢?

        如果返回值是一个对象,那么this指向的就是那个返回的对象,如果返回值不是一个对象那么this还是指向函数的实例。

2、在严格模式下是什么情况呢?

        在严格模式下,在全局环境中执行函数调用的时候 this 并不会指向 window 而是会指向 undefined

3、什么是严格模式?

        除了正常运行模式,ECMAscript 5添加了第二种运行模式:"严格模式"(strict mode)。顾名思义,这种模式使得Javascript在更严格的条件下运行。

设立"严格模式"的目的,主要有以下几个:

  • 消除Javascript语法的一些不合理、不严谨之处,减少一些怪异行为;
  • 消除代码运行的一些不安全之处,保证代码运行的安全;
  • 提高编译器效率,增加运行速度;
  • 为未来新版本的Javascript做好铺垫。

        "严格模式"体现了Javascript更合理、更安全、更严谨的发展方向,包括IE 10在内的主流浏览器,都已经支持它,许多大项目已经开始全面拥抱它。

        另一方面,同样的代码,在"严格模式"中,可能会有不一样的运行结果;一些在"正常模式"下可以运行的语句,在"严格模式"下将不能运行。掌握这些内容,有助于更细致深入地理解Javascript,让你变成一个更好的程序员。

4.拓展思考
Q1:apply方法有什么作用?一般在什么情况下可以使用apply?

        apply:方法能劫持另外一个对象的方法,继承另外一个对象的属性.,call:和apply的意思一样,只不过是参数列表不一样.。

        在给对象参数的情况下,如果参数的形式是数组的时候,比如apply示例里面传递了参数arguments,这个参数是数组类型,并且在调用Person的时候参数的列表是对应一致的(也就是Person和Student的参数列表前两位是一致的) 就可以采用 apply , 如果我的Person的参数列表是这样的(age,name),而Student的参数列表是(name,age,grade),这样就可以用call来实现了,也就是直接指定参数列表对应值的位置(Person.call(this,age,name,grade));

Q2:ES6是什么?

       ECMAScript 6(以下简称ES6)是JavaScript语言的下一代标准,在2015年6月正式发布。

Q3:bind是干什么用的?什么时候使用?

       bind()最简单的用法是创建一个函数,使这个函数不论怎么调用都有同样的this值。场景就是在绑定函数,偏函数,settimeout等

Q4:什么时候使用apply什么时候使用call

       传递参数是数组形式的时候用apply,反之使用call

  1. 参考文献

参考一:彻底理解js中this的指向

 


用户bPbdDlb
422 声望36 粉丝