JavaScript的this详解
1、全局作用域下的this:

2、一般函数与严格模式下的函数的this:

3、当函数的this作为对象的方法的情况下:

4、对象原型链上的this:

对象P的原型指向o, p.a与p.a创建对象p的属性,当调用p的原型上的方法的时候,this.a与this.b仍然能获取到对象p上的p.a与p.a属性;
需要注意一点,p的原型是o, 也就是说调用p.f()的时候也就是调用对象p原型链o上面的这一个函数属性f ,那么原型链O上面的这一个this仍然可以拿到p.a与p.a属性,也就是说不管这个this是原型链上的还是p对象本身的,当调用的时候,this也是可以指向P这样一个对象。
5、get/set方法下的this:

6、构造器下的this:

例子1:如果正常去调用这个this.a的话,这个this会指向全局对象,在浏览器里面,这个this就会指向window ;但是如果使用new把这个作为构造器去调用的话,那么这个this就会指向这样的一个空的对象,并且这个空对象的原型会指向MyClass.propertype属性 ; 使用new以后,this会指向原型为MyClass.propertype的属性的这样一个空对象 ,那么由于这个this.a=37是做了这样的一个赋值;所以最后的this会作为一个返回值,所以对象O会有这样的o.a的一个属性。
例子2:与例子1不同的是,c2函数里最后返回(return)了一个对象a:38 ;这个时候,打印出o.a的值就不是37了,而是38 ;原因是:当我们使用new在创建这样一个构造器去调用的时候,c2函数里的return语句返回的是一个对象的话,那么会将return的这个对象作为返回值,所以这里的o不再是this而是return里这个对象字面量的值。
7、call/apply方法下的this:

这里定义了一个变量o有两个属性:a:1,b:3 ;然后通过add对象的call()方法,把第一个参数(就是你想作为this的这个对象),后面的5与7就是我们想要去添加的参数,然后这里的5就会赋值给add对象参数里的c,这里的7就会赋值给add对象参数里的d ;最后的一个结果就是1+3+5+7=16 ;call与apply基本没有任何差别,call在传参的方式是点平传递过去的,而apply在传参的时候是作为一个数组去传递的;
注意:用到call与apply的情况有:当我们需要调用object.prototype.toString的时候,想要指定其中的某个this的时候
8、bind方法下的this:(在IE9+才可以使用)

通过bind方法 ; .bind()后面会有一个参数,参数里面的是一个对象,:这个对象就是你想要将某个对象作为this的时候,就把这样的一个对象传进去,那么就形成了一个新的对象,在后面console.log(g())调用的时候; 这个this已经指向这个bind的参数;
下面的var o ,是直接将a赋值为37,f属性直接赋值为f() ;g赋值为bind绑定的这样一个方法,那么输出f的这样一个结果可以拿到37;上面的例子可知,一般函数,我们根据调用方式来判断,o.f()是通过调用属性去调用的,那么this就会指向var o这个对象,也就是拿到了o.a也即是37;但是在使用bind的方法去绑定的时候,即使我们把新绑定的方法作为对象属性去调用,但是仍然只会按之前的bind绑定去做,于是仍然只返回test;
JavaScript的this详解的更多相关文章
- 从mixin到new和prototype:Javascript原型机制详解
从mixin到new和prototype:Javascript原型机制详解 这是一篇markdown格式的文章,更好的阅读体验请访问我的github,移动端请访问我的博客 继承是为了实现方法的复用 ...
- JavaScript严格模式详解
转载自阮一峰的博客 Javascript 严格模式详解 作者: 阮一峰 一.概述 除了正常运行模式,ECMAscript 5添加了第二种运行模式:"严格模式"(strict m ...
- [转]javascript console 函数详解 js开发调试的利器
javascript console 函数详解 js开发调试的利器 分步阅读 Console 是用于显示 JS和 DOM 对象信息的单独窗口.并且向 JS 中注入1个 console 对象,使用该 ...
- javascript 节点属性详解
javascript 节点属性详解 根据 DOM,html 文档中的每个成分都是一个节点 DOM 是这样规定的:整个文档是一个文档节点每个 html 标签是一个元素节点包含在于 html 元素中的文本 ...
- (" use strict")Javascript 严格模式详解
Javascript 严格模式详解 转载别人的博客内容,浏览了一遍,没有全部吸收,先保存一下链接 http://www.ruanyifeng.com/blog/2013/01/javascript_s ...
- 【HANA系列】SAP HANA XS使用JavaScript数据交互详解
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列]SAP HANA XS使用Jav ...
- JavaScript运行机制详解
JavaScript运行机制详解 var test = function(){ alert("test"); } var test2 = function(){ alert(& ...
- [转]JavaScript异步机制详解
原文: https://www.jianshu.com/p/4ea4ee713ead --------------------------------------------------------- ...
- js课程 1-3 Javascript变量类型详解
js课程 1-3 Javascript变量类型详解 一.总结 一句话总结:js对象点(属性方法),json对象冒号(属性方法).属性和方法区别只有一个括号. 1.json对象中的函数的使用? 函数名 ...
- JavaScript数组方法详解
JavaScript数组方法详解 JavaScript中数组的方法种类众多,在ES3-ES7不同版本时期都有新方法:并且数组的方法还有原型方法和从object继承的方法,这里我们只介绍数组在每个版本中 ...
随机推荐
- 编解码器的学习笔记(十):Ogg系列
Ogg是一个自由和开放的标准容器格式,由Xiph.Org 维修基金. Ogg格式不受软件专利的限制,它的目的是有效地处理高品质的流媒体和数字媒体. Ogg意指一种文件格式,能够纳入各式各样自由和开放源 ...
- javascript this指向
this对象是什么: this对象是与运行时函数执行的上下文绑定的.这句话其实已经很好的解释了this对象,为我们确定this指明了方向!但是需要注意的是:由于javascript具有动态性(解释执行 ...
- ASP.NET MVC IOC之Unity攻略
ASP.NET MVC IOC之Unity攻略 一.你知道IOC与DI吗? 1.IOC(Inversion of Control )——控制反转 即依赖对象不在被依赖模块的类中直接通过new来获取 先 ...
- MVC 5显示、创建、编辑、删除等功能实练
MVC 5显示.创建.编辑.删除等功能实练 在前天的学习小结中<15天学习MVC后的小结(分享经历与想法)>http://www.cnblogs.com/insus/p/3369870.h ...
- Linux环境进程间通信(三):消息队列
linux下进程间通信的几种主要手段: 管道(Pipe)及有名管道(named pipe):管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具有的功能外,它还允 ...
- 企业架构研究总结(28)——TOGAF架构开发方法(ADM)之需求管理阶段
1.11 需求管理(Requirements Management) 企业架构开发方法各阶段——需求管理 1.11.1 目标 本阶段的目标是定义一个过程,使企业架构的需求可以被识别.存储并与其他架构开 ...
- 基于Redis的CustomerSessionProvider(一)
CustomerSessionProvider需要实现SessionStateStoreProviderBase 在设计Redis Session Provider的时候,需要考虑 1.是否每个用户的 ...
- 程序处理数据库中值字段值为null的查询显示
1.如果你做了一个简单的注册界面,需要用户进行注册,但有些项是不必要填的,当用户完成注册时,数据库表中的相应字段的值会写入null,但如何将查询的字段的值null显示出来? 2.首先我们学习一下如何向 ...
- 译文:User-agent的历史
这是一篇译文,译文出处在文章底部贴出.由于技术水平,英语水平,翻译水平有限,请各路大侠多多指正,谢谢,提高你也提高我:) 几个礼拜之前,我谈论了特征检测和浏览器检测.这篇帖子提到了一点点嗅探U ...
- uva 408 Uniform Generator
Uniform Generator Computer simulations often require random numbers. One way to generate pseudo-ran ...