美文网首页
JS中this的指向

JS中this的指向

作者: 晚_cc3a | 来源:发表于2018-03-19 21:26 被阅读0次


       大家好,我是IT修真院北京总院第29期的学员禚洪宇,一枚正直、纯洁、善良的前端程序员今天给大家分享一下,修真院官网JS任务4深度思考中的知识点——JS中this的指向。

1、背景介绍

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

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

1.1 THIS的特性

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

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

2.知识剖析

2.1 作为普通函数在全局环境中被调用

       先上代码:

全局环境中的普通对象

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

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

2.2 作为对象的属性被调用

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

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

2.3 作为构造函数被调用

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

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

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

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

3.常见问题

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

        什么意思呢?

        如果返回值是一个对象,那么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

5. 参考文献

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

参考二:慕课网:学会JS的this这一篇就够了,根本不用记

参考三:知乎:十分钟读懂 JavaScript 中的 this

PPT


undefined_腾讯视频

加入IT修真院  邀请码:18238266

相关文章

  • JS进阶篇-this指向问题

    JS中this的指向问题不同于其他语言,JS中的this不是指向定义它的位置,而是在哪里调用它就指向哪里。 JS中...

  • JS中this指向

    一、全局作用域中的thises5与es6中严格模式与非严格模式全局函数的this都指向window 二、全局作用域...

  • JS中this指向

    函数有4种调用方式,对应就有4种绑定规则:默认绑定、隐式绑定、硬绑定和构造函数绑定。 1、默认绑定 当作为普通函数...

  • js中this指向

    1.this总是指向函数的直接调用者2.如果有new关键字,this指向new出来的那个对象3.DOM事件中thi...

  • JS中this指向

    (1)事件调用环境:谁触发事件,函数里面的this指向就是谁(某个DOM)。 (2)node全局环境:this指向...

  • js中this指向

    当我们需要把函数当做另外函数参数传入时,我们使用箭头函数。 关于this的指向。 问题:箭头函数中的this是如何...

  • JS中this的指向

    什么是this? 它是函数运行时,在函数体内部自动生成的一个对象,只能在函数体内部使用。 JS中this的指向,取...

  • JS中this的指向

    JS中this的指向 1.背景介绍 2.知识剖析 3.常见问题 4.解决方案 5.编码实战 6.扩展思考 7.参考...

  • JS中this的指向

    1、普通函数中this的指向( 普通函数中的this指针指向于调用者) 2、定时器中的this的指向 3、在对象...

  • JS中THIS的指向?

    大家好,我是IT修真院北京分院第22期的学员杨纲,一枚正直纯洁善良的WEB前端程序员。 1.背景介绍 this对象...

网友评论

      本文标题:JS中this的指向

      本文链接:https://www.haomeiwen.com/subject/ocimmxtx.html