这里是修真院前端小课堂,每篇分享文从javascript
【背景介绍】【知识剖析】【常见问题】【解决方案】【编码实战】【扩展思考】【更多讨论】【参考文献】html
八个方面深度解析前端知识/技能,本篇分享的是:前端
【简述JS中this的指向 】java
一、背景介绍
咱们在写代码时候每每但愿一个函数在不一样环境下行为风格一致可是具体表现不同,这个时候就须要this出场了。程序员
this是javascript的一个关键字,是函数内部的一个特殊对象(或this引用);this在不一样的上下文执行环境中指代不一样的对象,因此咱们能够用一样的this代码输出不一样的结果,从而简化代码。数组
1.1 THIS的特性浏览器
会根据代码上下文语境自动改变其引用对象安全
this的指向在函数定义的时候是肯定不了的,只有函数执行的时候才能肯定this到底指向谁,实际上this的最终指向的是那个调用它的对象。app
2.知识剖析
2.1 做为普通函数在全局环境中被调用函数
先上代码:
全局环境中的普通对象
这里调用了a函数,而a函数的执行环境是全局环境,这里的this也就指向了全局变量window。
在全局环境里面,this 永远指向 window,所以在全局环境里做为普通函数被调用的时候,this 也是指向 window。
2.2 做为对象的属性被调用
先来个总结:若是函数做为一个对象的属性方法,而且被调用的时候,那么这个属性方法中的this 就指向这个对象,来看代码:
.png](/img/bVbmXa0)
![图片上传中...]
可是当在在对象方法中再定义函数,这时候 this 又是 window
2.3 做为构造函数被调用
做为构造函数被调用的时候,this 表明它即将 new 出来的对象;若是不加 new,表示即做为普通函数调用,指向 window。
2.4做为 call/apply/bind 方法的调用
做为 call/apply/bind 方法被调用的时候指向传入的值。
2.5 其余:setTimeout、setInterval中的this;构造函数 prototype 属性; Eval函数;箭头函数.。
3.常见问题
一、this 遇到return怎么办呢?什么意思呢,来看
什么意思呢?
若是返回值是一个对象,那么this指向的就是那个返回的对象,若是返回值不是一个对象那么this仍是指向函数的实例。
二、在严格模式下是什么状况呢?
在严格模式下,在全局环境中执行函数调用的时候 this 并不会指向 window 而是会指向 undefined
三、什么是严格模式?
除了正常运行模式,ECMAscript 5添加了第二种运行模式:"严格模式"(strict mode)。顾名思义,这种模式使得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
参考一:完全理解js中this的指向