一、函数内 this 的指向

1、 this 的指向是当调用函数时确定的,调用的方式不同,this 的指向也就不同。

1.1 this 一般是指向调用者。

函数类型 this 的指向
普通函数 Window
定时器函数 Window
立即执行函数 Window
对象方法 对象本身
构造函数(原型对象) 实例对象

2、改变函数内部 this 指向

常用的 3 种方法:call()、apply()和bind()。

2.1 call('this 指向的对象','参数1','参数2')

  • 改变 this 指向,调用自身函数

    let obj = {
    name:'Coder Yarn';
    }; function fn(a,b){
    console.log(this);
    console.log(a + b);
    }; fn.call(obj,2,5); //输出结果
    {name:'Coder Yarn';}
    7
  • 可以实现继承
    function Father(username,age,sex){
    this.username = username;
    this.age = age;
    this.sex = sex;
    }; function Son(username,age,sex){
    Father.call(this,username,age,sex);
    }; //实例化对象
    let son = new Son('Coder Yarn','22','男');
    console.log(son); //结果输出
    Coder Yarn
    22

2.2 apply(thisArg, [argArray])

thisArg: 在 fun 函数运行时指定的 this 值。  argArray:传递的参数,必须包含在数组中

返回值就是函数的返回值,因为他就是调用函数


  • 改变 this 指向,调用自身的函数
  • 传的参数必须是数组(伪数组)
    //通过数学的内置方法求数组的最大值//
    
    let arr = [3,55,88,7,9];
    
    let max = Math.max.apply(Math,arr);        //this 指向 Math 实例
    console.log(max); //输出结果
    88

2.3 bind(thisArg,arg1,arg2,....)

thisArg:在 fun() 函数运行时指定的 this 值。  arg1,arg2:传递其他参数

返回由指定的 this 值和初始化参数改造的原函数拷贝,即返回一个新的函数


  • 可以改变 this 的指向,但是不能调用自身的函数,只有返回的新函数可以调用自身的函数

    let obj = {
    name:'Coder Yarn';
    }; function fun(a,b){
    console.log(this);
    console.log(a + b);
    }; let newfun = fun.bind(obj,2,3);
    newfun(); //输出结果
    {name:'Coder Yarn';}
    5
  • bind() 的应用:函数不需要立即调用,但是想改变函数内部的 this 指向。  如:点击按钮后禁用按钮,经过 1 秒后在启用按钮
    //获取 button 按钮元素
    let btn = document.querySelector('button'); btn.onclick = function(){
    this.disabled = true; //this 指向的是 btn //计时器
    setTimeout(function(){
    this.disabled = false; //没有 bind() 方法时 this 的指向是 window ,使用 bind() 方法后 this 指向 btn
    }.bind(this),1000);
    }; //输出结果自己去实现一下吧

三、3 者的区别

  • call() 和 apply() 相同点:都会到用自身函数,并且该别函数内部 this 的指向;
  • call() 和 apply() 不同点:传入的参数不一样,call 是正常传参,而 apply 必须传入的是数组形式 [];
  • bind() 不会调用自身函数,但可以改变函数内部的 this 指向。

如何改变函数内部 this 的指向的更多相关文章

  1. 改变函数中的 this 指向——神奇的call,apply和bind及其应用

    在JavaScript 中,call.apply 和 bind 是 Function 对象自带的三个方法,这三个方法的主要作用是改变函数中的 this 指向,从而可以达到`接花移木`的效果.本文将对这 ...

  2. js修改函数内部的this指向(bind,call,apply)

    js修改函数内部的this指向 在调用函数的时候偶尔在函数内部会使用到this,在使用this的时候发现并不是我们想要指向的对象.可以通过bind,call,apply来修改函数内部的this指向. ...

  3. js函数( 普通函数、箭头函数 ) 内部this的指向

    - 普通函数   | 具名普通函数.匿名普通函数,在不作为对象的属性值的情况下,其内部的 this 总是指向代码运行环境下的全局对象 ( 例如,浏览器中的 window ). 示例: (functio ...

  4. 改变javascript函数内部this指针指向的三种方法

    在查了大量的资料后,我总结了下面的三条规则,这三条规则,已经可以解决目前我所遇到的所有问题.规则0:函数本身是一个特殊类型,大多数时候,可以认为是一个变量. function a() { alert( ...

  5. 函数高阶(函数,改变函数this指向,高阶函数,闭包,递归)

    一.函数的定义方式 1.函数声明方式 function  关键字(命名函数) 2.函数表达式(匿名函数) 3.new  Function( ) var  fn = new  Function(‘参数1 ...

  6. 作用域链和函数内部this指向问题以及bind、call、apply方法

    作用域链和函数内部this指向问题以及bind.call.apply方法 作用域链 作用域是相对于变量而言的, 其意义就在与查找变量(确定变量的来处, 变量是否可以访问到, 确定变量在当前位置是否可以 ...

  7. JS回调函数中的this指向(详细)

    首先先说下正常的this指向问题 什么是this:自动引用正在调用当前方法的.前的对象. this指向的三种情况 1. obj.fun()     fun中的this->obj,自动指向.前的对 ...

  8. 关于Java函数传参以及参数在函数内部改变的问题——JAVA值传递与引用最浅显的说明!

    看了很多关于阐述JAVA传参到底是值传递还是引用的问题,有些说得很肤浅让人感觉似懂非懂的感觉,但是好像又能解决一些问题,然后就止步了.还有一些则是,讲得很深奥,看着好像很有道理的样子,但是其实还是没怎 ...

  9. 函数内部的函数中的this都是指向window

    刚看到一个问题关于this的, var name="the window"; var object={ name:"silence", packname:fun ...

随机推荐

  1. Oracle数据常用的备份与恢复?

    Oracle的备份与恢复有三种标准的模式,大致分为两大类,备份恢复(物理上的)以及导入导出(逻辑上的),而备份恢复又可以根据数据库的工作模式分为非归档模式(Nonarchivelog-style)和归 ...

  2. Dubbo 和 Spring Cloud 的区别?

    根据微服务架构在各方面的要素,看看 Spring Cloud 和 Dubbo 都提供了哪些支 持. Dubbo Spring Cloud 服务注册中心 Zookeep er Spring Cloud ...

  3. MySQL 里有 2000w 数据,redis 中只存 20w 的数据,如 何保证 redis 中的数据都是热点数据?

    Redis 内存数据集大小上升到一定大小的时候,就会施行数据淘汰策略. 相关知识:Redis 提供 6 种数据淘汰策略: volatile-lru:从已设置过期时间的数据集(server.db[i]. ...

  4. 解释 MySQL 外连接、内连接与自连接的区别 ?

    先说什么是交叉连接: 交叉连接又叫笛卡尔积,它是指不使用任何条件,直接将一 个表的所有记录和另一个表中的所有记录一一匹配. 内连接 则是只有条件的交叉连接,根据某个条件筛选出符合条件的记录,不符合 条 ...

  5. 将项目导入eclipse中出现的jsp页面报错

    图片摘自百度经验,实在是每次都会忘了步骤,每次都得重新百度,所以索性自己总结到博客中,下次如果还记不住就直接从博客中看.原谅我实在学渣,呜呜~~~~(>_<)~~~~

  6. mysql绿色版安装以及遇到的问题

    下载mysql绿色版 放在如下文件夹  D:\javaSkill\mysql 修改my.ini文件内容: [mysql] default-character-set=utf8 [mysqld] bas ...

  7. 循序渐进搞懂 TCP 三次握手核心

    前言 本文旨在通过形象的例子和实操,把无形的.虚拟的网络转为具体的.可视化的.带领网络小白一步步的掌握 TCP 三次握手核心知识点,为后续深入学习 TCP 协议打基础. 通俗版 如下图所示,小明(客户 ...

  8. [源码解析] TensorFlow 分布式环境(8) --- 通信机制

    [源码解析] TensorFlow 分布式环境(8) --- 通信机制 目录 [源码解析] TensorFlow 分布式环境(8) --- 通信机制 1. 机制 1.1 消息标识符 1.1.1 定义 ...

  9. Docker-操作容器1

    ->点击该链接:Linux(Centos7)安装Docker<- 前言 步骤: 软件镜像->运行镜像->产生一个容器 这就类似于我们在pc端下载微信时需要启动wechat.ex ...

  10. 北桥芯片(north bridge/host bridge)

    看下上面的图,会比较清晰的认识到北桥芯片所在位置 北桥芯片(North Bridge) 是mother board chipset(主板芯片组) 中起主导作用的最重要的组成部分,也称为主桥(Host ...