因为JavaScript 中this 是在运行期进行绑定的,因此JavaScript 中this 关键字具备多重含义。

具体在实际应用中,this的指向大致可以分为下面4种。

  1. 作为对象的方法调用   obj.a()
  2. 作为普通函数调用    a()
  3. 构造函数调用        var b = new a(); 
  4. function.prototype.call或function.prototype.apply调用

作为对象的方法调用 和 作为普通函数调用

  1. window.a = 2;
  2. var obj = {
  3. a:1,
  4. getA:function(){
  5. console.log(this.a);
  6. }
  7. }
  8. obj.getA(); //输出1,作为对象的方法调用,this指向当前对象
  9. var x = obj.getA;
  10. x(); //输出2,作为普通函数调用,this全部指向window对象。

注意,不管x之前是obj.getA,还是其他某个对象的属性,只要最后是以x(),fun()这种方式调用的,均视为普通函数调用,此时this指向window对象

但是,在ECMAScript5的strict模式下,作为函数调用的 this被规定不会指向全局对象

  1. window.a = 2;
  2. var obj = {
  3. a:1,
  4. getA:function(){
  5. "use strict"
  6. console.log(this.a);
  7. }
  8. }
  9. var x = obj.getA;
  10. x(); //underfined

作为构造函数调用

通常情况下,构造函数里的this指向返回的这个对象,但是如果构造器显示地返回了一个object类型的对象,则this指向这个返回的object对象
  1. var Myclass = function(){
  2. this.name = 'beidan';
  3. }
  4. var obj = new Myclass();
  5. console.log(obj.name);//beidan
  6.  
  7. var Myclass = function(){
  8. this.name = 'beidan';
  9. return{ //显示的返回一个对象,注意!既要是显示,即有return,也要是对象{}
  10. name:'test'
  11. }
  12. }
  13. var obj = new Myclass();
  14. console.log(obj.name);//test

作为function.prototype.call或function.prototype.apply调用

  • 理解call,apply

call,apply都是为了改变函数体内部 this 的指向。例如,fun1.call()或者fun1.apply() 都是为了改变fun1函数内部的this指向。

二者的作用完全一样,只是接受参数的方式不太一样。

func1.call(this, arg1, arg2);        //参数列表arg1,arg2
func1.apply(this, [arg1, arg2]);   //参数数组 [arg1,arg2]
 
第一个参数指定那个了函数体内this对象的指向,他可以任何一个 JavaScript 对象(JavaScript 中一切皆对象),如果为null,则函数体内的this会指向默认的宿主对象,在浏览器中则是window。
 
第二个参数,call 需要把参数按顺序传递进去,而 apply 则是把参数放在数组里。
当你的参数不确定数量时用 apply ,然后把参数 push 进数组传递进去。或者也可以通过 arguments来获取所有的参数。这样看来,apply的使用率更高。
 
  • call,apply的用途
1.修正this的指向
比如,在实际开发中,会出现以下这种问题
  1. document.getElementById('div1').onclick = function(){
  2. console.log(this.id); //div1
  3. var func = function(){
  4. console.log(this.id);
  5. }
  6. func(); //通过普通函数调用,this指向window,输出undefined
  7. }
这时我们可以用call来修正func 函数内this的指向。
  1. document.getElementById('div1').onclick = function(){
  2. console.log(this.id); //div1
  3. var func = function(){
  4. console.log(this.id);
  5. }
  6. func.call(this); //使用call,使func函数内部的this指向当前的函数对象,输出div1
  7. }

2.模拟继承(借用其他对象的方法)

  • 例子一:其他对象(banana)借用apple中的say方法
  1. function fruits() {}
  2. fruits.prototype = {
  3. color: "red",
  4. say: function() {
  5. console.log("My color is "+ this.color);
  6. }
  7. }
  8. var apple = new fruits;
  9. apple.say(); //My color is red

但是,如果我们还有其它 2个对象 banana= {color : "yellow"} ,orange = {color:‘orange’},想使用say方法,但是又不想对它们重新定义say方法。

那么,我们可以用apply或者call 借用 fruit里面的say方法
  1. banana = {
  2. color: "yellow"
  3. };
  4. orange = {color:‘orange’};
  5. apple.say.call(banana); //My color is yellow
  6. apple.say.apply(orange ); //My color is orange

也就是说,当一个 object 没有某个方法(本例子中banana没有say方法),但是其他的有(本例子中apple有say方法),我们可以借助call或apply用其它对象的方法来操作。

再看几个例子巩固记忆
  • 例子二:获取数组中的最大值和最小值
  1. var numbers = [5, 458 , 120 , -215 ];
  2. var maxInNumbers = Math.max.apply(Math, numbers), //
  3. maxNumbers = Math.max.call(Math,5, 458 , 120 , -215, 666); //

number 本身没有 max 方法,但是 Math 有,我们就可以借助 call 或者 apply 使用其方法。

以上就是this在JavaScript中不同情况下的指向。

如果这篇文章对你有帮助,就给我一点赞赏吧~~~

通俗易懂------this指向的更多相关文章

  1. 通俗易懂浅谈理解ES6类this不同指向问题

    1. class Btn{ //定义的一个类 constructor(id){ // constructor是一个构造函数,是一个默认方法,通过 new 命令创建对象实例时,自动调用该方法.一个类必须 ...

  2. 关于一个通俗易懂的FFT的C语言实现教程

    找到一个通俗易懂并且神奇并且有趣的FFT算法C语言实现教程:http://www.katjaas.nl/FFTimplement/FFTimplement.html 只要对矩阵比较熟悉就能在教程的辅助 ...

  3. JS中OOP之模拟封装和继承和this指向详解

    大家好,今天我带大家学习一下js的OOP, 大家都知道,面向对象有三个基本特征,继承,封装和多态,面向对象的语言有那么几种,C++,PHP,JAVA等,而功能强大的JS可以模拟实现面向对象的两大特征, ...

  4. 常用DOS命令之通俗易懂篇

    目录 常用DOS命令之通俗易懂篇 Arp 命令 Assoc 关联 At 计划服务 Attrib 属性 Cd=chdir 目录 Cipher Cls 清屏 Color 颜色 Comp 比较 Compac ...

  5. 1. 通俗易懂解释知识图谱(Knowledge Graph)

    1. 通俗易懂解释知识图谱(Knowledge Graph) 2. 知识图谱-命名实体识别(NER)详解 3. 哈工大LTP解析 1. 前言 从一开始的Google搜索,到现在的聊天机器人.大数据风控 ...

  6. 通俗易懂,C#如何安全、高效地玩转任何种类的内存之Span的脾气秉性(二)。 异步委托 微信小程序支付证书及SSL证书使用 SqlServer无备份下误删数据恢复 把list集合的内容写入到Xml中,通过XmlDocument方式写入Xml文件中 通过XDocument方式把List写入Xml文件

    通俗易懂,C#如何安全.高效地玩转任何种类的内存之Span的脾气秉性(二).   前言 读完上篇<通俗易懂,C#如何安全.高效地玩转任何种类的内存之Span的本质(一).>,相信大家对sp ...

  7. 通俗易懂,什么是.NET?什么是.NET Framework?什么是.NET Core? .Net Web开发技术栈

    通俗易懂,什么是.NET?什么是.NET Framework?什么是.NET Core?   什么是.NET?什么是.NET Framework?本文将从上往下,循序渐进的介绍一系列相关.NET的概念 ...

  8. 通俗易懂,什么是.NET?什么是.NET Framework?什么是.NET Core?(转)

    通俗易懂,什么是.NET?什么是.NET Framework?什么是.NET Core?(转) 一.总结 一句话总结:.NET是一个平台,包含多种语言,比如(C#.Visual Basic.C++/C ...

  9. 3万字长文概述:通俗易懂告诉你什么是.NET?什么是.NET Framework?什么是.NET Core?

    [转载]通俗易懂,什么是.NET?什么是.NET Framework?什么是.NET Core? 什么是.NET?什么是.NET Framework?本文将从上往下,循序渐进的介绍一系列相关.NET的 ...

随机推荐

  1. JavaScript Patterns 4.1 Functions Background

    Functions are first-class objects and they provide scope. • Can be created dynamically at runtime, d ...

  2. php 修改上传文件大小 (max_execution_time post_max_size)

    有些朋友要通过自己的网站后台,包括论坛,来上传一些文件,php一般为2m,或8m(以下我们按默认为2m),接下来就是来讲怎么修改上传文件大小的. 1.首先修改执行上传文件限制 一般的文件上传,除非文件 ...

  3. maven 仓库搜索添加需要的jar包

    可用仓库网址: http://search.maven.org/#browse http://mvnrepository.com/ http://repository.sonatype.org/ind ...

  4. 烂泥:KVM虚拟机随KVM服务器的启动而启动

    本文由秀依林枫提供友情赞助,首发于烂泥行天下. 要使KVM虚拟机随KVM服务器的启动而启动,我们所需要做的工作很少.只需要把KVM虚拟机的XML配置文件做一个软连接到/etc/libvirt/qemu ...

  5. 烂泥:kvm安装windows系统蓝屏

    本文由秀依林枫提供友情赞助,首发于烂泥行天下. 最近一直在学习有关KVM的知识,实验一直是在虚拟机VM中进行的.今天刚好公司有一台空闲的服务器,直接拿来安装centos.kvm等等,然后相关的配置. ...

  6. 利用Windows自带的Certutil查看文件MD5

    当遇到需要对比两个文件是否一致时,可以使用下面的命令来显示文件的MD5, 然后对比两个文件的MD5码. certutil -hashfile <filename> MD5 命令的相关帮助信 ...

  7. uva 725 division(水题)——yhx

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABVMAAAOHCAIAAAClwESxAAAgAElEQVR4nOydybGturJFcQEPfgQu4A

  8. 《TCP/IP详解 卷一》读书笔记-----DNS

    1.DNS是一个分布式数据库系统用来提供主机名和IP地址之间的映射,之所以称为分布式原因的原因是因特网上没有一台主机知道这类映射的全部信息,当然也不可能做到,因为数据量实在太大了 2.应用程序通过一个 ...

  9. 边工作边刷题:70天一遍leetcode: day 70

    Design Phone Directory 要点:坑爹的一题,扩展的话类似LRU,但是本题的accept解直接一个set搞定 https://repl.it/Cu0j # Design a Phon ...

  10. Python天猫淘宝评论爬虫

    说明 由于Github 打包的exe某些文件上传被.gitignore了,所以不提供windows二进制包 https://github.com/hunterhug/taobaocomment 一个抓 ...