一、函数的不同调用方式决定了this的指向不同,一般指向调用者
1.普通函数   this指向window的调用者
       function fn(){
           console.log('普通函数的this'+this);
       }
       window.fn();
2.对象的方法 this指向的是对象o (object)
       var o={
           sayHi:function(){
               console.log('对象方法this:'+this);
           }
       }
       o.sayHi();
3.构造函数 this指向ldh这个实例
       原型对象里面的this指向的是ldh这个实例对象
        function Star(){}
        Star.prototype.sing=function(){ }
        var ldh=new Star();
4.绑定事件函数this指向的是函数调用者 btn这个按钮对象
        var btn=document.querySelector('button');
        btn.onclick=function(){
            console.log('绑定事件函数的this:'+this);
        }
 5.定时器函数  this 指向的也是window
       window.setTimeout(function(){
           console.log('定时器的this'+this);
       },1000);
6.立即执行函数 this指向window
       (function(){
           console.log('立即执行函数的this'+this);
       })();
二、改变函数内部的this指向
 JavaScript为我们专门提供了一些函数方法帮我们处理函数内部this的指向问题,常用方法有
 bind()、call()、apply()三种方法 ,call()方法调用一个对象,简单理解为调用函数的方式,但是
 它可以改变函数的this指向

fun.call(thisArg,arg1,arg2);
1.call()
       var o={
           name:'any'
       }
       function fn(a,b){
           console.log(this);
           console.log(a+b);
       }
      fn.call(o,1,2);
 //call第一个可以调用函数,第二个可以改变函数内的this指向
 //call的主要作用可以实现继承
 function Father(uname,age,sex){
          this.uname=uname;
          this.age=age;
          this.sex=sex;
      }
      function Son(uname,age,sex){
          Father.call(this,uname,age,sex);
      }
      var son=new Son('刘德华',19,'男');
      console.log(son);
2.apply() 应用
      var o={
          name:'any'
      }
      function fn(arr){
          console.log(this);
          console.log(arr);//'pink'
      }
      fn.apply(o,['pink']);
      //1.也是调用函数 第二个可以改变函数内部的this指向
      //2.但是他的参数必须是数组(伪数组)
      //3.apply的主要应用 比如说我们可以利用apply借助于
      //数学内置对象求最大值
      //Math.max();
      var arr=[1,32,56,88];
    //var max= Math.max.apply(null,arr);
     var max= Math.max.apply(Math,arr);
     var min= Math.min.apply(Math,arr);
     console.log(max,min);
3.bind() 绑定
    <button>点击</button>
    <button>点击</button>
    <button>点击</button>
    var o={
        name:'andy'
    };
    function fn(a,b){
        console.log(this);
        console.log(a+b);
    };
    var f= fn.bind(o,1,2);
       f();
       //1.不会调用原来的函数 可以改变原来函数内部的this指向
       //2.返回的是原函数改变this之后产生的函数
       //3.如果有的函数我们不需要立即调用,但是又想改变这个函数内部
       //的this指向,此时用bind
          var btn =document.querySelector('button');
         btn.onclick=function(){
             this.disabled=true;//this指向的是btn
                //var that=this;
         setTimeout(function(){
        //    that.disabled=false;//定时器函数里面的this指向window
                this.disabled=false;//此时定时器函数里面的this指向的是btn
              }.bind(this),3000)//这个this指向的是btn这个对象
          }   
        
        var btns=document.querySelectorAll('button');
        for(var i=0;i<btns.length;i++){
            btns[i].onclick=function(){
                this.disabled=true;
                setTimeout(function(){
                 this.disabled=false;
                }.bind(this),3000)
            }
        }
 
 
三、call apply bind总结
         相同点:
         都可以改变函数内部的this指向
         区别点:
         1.call和apply会调用函数并且改变函数内部的this指向
        2.call和apply传递的参数不一样,call传递参数aru1、aru2形式
           apply必须数组形式[arg]
        3.bind不会调用函数,可以改变函数内部的this指向。
       主要应用场景:
         1.call经常做继承
         2.apply经常跟数组有关系,比如借助数学对象实现数组最大值和最小值
         3.bind不调用函数,但是还是想改变this指向,比如改变定时器内部的this指向。

函数的不同调用方式决定了this的指向不同的更多相关文章

  1. JS的一些总结(函数声明和函数表达式的区别,函数中的this指向的问题,函数不同的调用方式,函数也是对象,数组中的函数调用)

    一.函数声明和函数表达式的区别: 函数声明放在if——else语句中,在IE8中会出现问题 函数表达式则不会 <script> if(true){ function f1(){ conso ...

  2. JS高级---函数中的this的指向,函数的不同调用方式

    函数中的this的指向 普通函数中的this是谁?-----window 对象.方法中的this是谁?----当前的实例对象 定时器方法中的this是谁?----window 构造函数中的this是谁 ...

  3. js函数的四种调用方式以及对应的this指向

    一.函数调用,此时this是全局的也就是window 1 var c=function(){ 2 alert(this==window) 3 } 4 c()//true 二.方法调用 var myOb ...

  4. 函数四种调用模式以及其中的this指向

    第一种:函数直接执行模式 function add(a,b){ console.log(this); return a+b; } add(10,20)//this===window 第二种:对象方法的 ...

  5. Javascript中函数的四种调用方式

    一.Javascript中函数的几个基本知识点: 1.函数的名字只是一个指向函数的指针,所以即使在不同的执行环境,即不同对象调用这个函数,这个函数指向的仍然是同一个函数. 2.函数中有两个特殊的内部属 ...

  6. javascript 函数的4种调用方式与 this(上下文)的指向

    前言:这是笔者学习之后自己的理解与整理.如果有错误或者疑问的地方,请大家指正,我会持续更新! javascript中作用域链和this(上下文)的指向是很容易混淆的,简单的说就是: 作用域链取决于函数 ...

  7. JavaScript函数的声明与调用方式

    入职第一天小记 对于初入前端的程序猿来说,对于函数的理解与使用可谓是相当浅薄的,回顾这自己近几年的工作以及学习经历,准备对JavaScript来个系统的总结. 如果要我们对H5中的表单做个简单的校验, ...

  8. 浅谈js函数三种定义方式 & 四种调用方式 & 调用顺序

    在Javascript定义一个函数一般有如下三种方式: 函数关键字(function)语句: function fnMethodName(x){alert(x);} 函数字面量(Function Li ...

  9. JS调用函数的两种方式

    <script type="text/javascript"> window.onload = init; //onload 表示页面全部加载完毕后,再调用init() ...

随机推荐

  1. 作业十一——LL(1)文法的判断,递归下降分析程序

    作业十一——LL(1)文法的判断,递归下降分析程序 判断是否为LL(1)文法 选取有多个产生式的求select,只有一条产生式的无需求select 同一个非终结符之间求交集,全部判断为空后则为LL(1 ...

  2. Redis持久化存储(三)

    redis高级特性-发布订阅消息服务功能 Pub/Sub 订阅,取消订阅和发布实现了发布/订阅消息范式(引自wikipedia),发送者(发布者)不是计划发送消息给特定的接收者(订阅者).而是发布的消 ...

  3. Spring5参考指南:依赖注入

    文章目录 依赖注入 依赖注入的配置详解 depends-on lazy-init 自动装载 方法注入 依赖注入 依赖注入就是在Spring创建Bean的时候,去实例化该Bean构造函数所需的参数,或者 ...

  4. 【JAVA基础】06 面向对象

    1. 面向对象思想概述 面向过程思想概述 第一步 第二步 面向对象思想概述 找对象(第一步,第二步) 举例 买煎饼果子 洗衣服 面向对象思想特点 是一种更符合我们思想习惯的思想 可以将复杂的事情简单化 ...

  5. JavaScript实现插入排序

    一.插入排序简介: 想象我们斗地主,摸排阶段,手里的牌都按照从小到大排序.如果每摸一张牌,我们就把他插入合适的位置,使得它比后面位置的牌小,比前面位置的牌大或者相等. 类似这样的一种排序方法就是插入排 ...

  6. CF思维联系– CodeForces - 991C Candies(二分)

    ACM思维题训练集合 After passing a test, Vasya got himself a box of n candies. He decided to eat an equal am ...

  7. JMeter Nmon Tool V2.0 插件

    很早之前宝路已将nmon监控功能集成到了JMeter中,自己在使用旧版本时,也有诸多不满意的地方.趁着五一假期(基本都是晚上,白天要陪孩子),对插件底层代码进行了重构,自己还要反复测试调整,最晚的一次 ...

  8. js获取session对象

  9. 201771010113 李婷华 《面向对象程序设计(java)》第十五周总结

    一.理论知识部分 JAR文件 Java程序的打包:程序编译完成后,程序员将.class文件压缩打包为.jar文件后,GUI界面程序就可以直接双击图标运行. .jar文件(Java归档)既可以包含类文件 ...

  10. 【Spark】必须要用CDH版本的Spark?那你是不是需要重新编译?

    目录 为什么要重新编译? 步骤 一.下载Spark的源码 二.准备linux环境,安装必须软件 三.解压spark源码,修改配置,准备编译 四.开始编译 为什么要重新编译? 由于我们所有的环境统一使用 ...